Mybatis 級(jí)聯(lián)刪除的實(shí)現(xiàn)
需求描述
今日需求是刪除資源時(shí)同時(shí)刪除與該資源綁定的角色數(shù)據(jù),有兩張表,資源表、角色與資源綁定表,級(jí)聯(lián)刪除的時(shí)候有兩種方法:①建立表時(shí)直接建立約束,當(dāng)父表刪除數(shù)據(jù)時(shí)數(shù)據(jù)庫(kù)會(huì)自動(dòng)去刪除子表中的數(shù)據(jù),②通過(guò)代碼實(shí)現(xiàn)級(jí)聯(lián)刪除,先刪除子表數(shù)據(jù),然后刪除父表中的數(shù)據(jù)。
通過(guò)數(shù)據(jù)庫(kù)實(shí)現(xiàn)
可以參考博文://www.dbjr.com.cn/article/88148.htm
這種方式假如我們要?jiǎng)h除父表的數(shù)據(jù),子表的數(shù)據(jù)就會(huì)被刪除,而我們的業(yè)務(wù)需求是表中是否刪除由is_delete字段來(lái)標(biāo)識(shí),所以這種方式是可以實(shí)現(xiàn)級(jí)聯(lián)表刪除的,但是不符合我們的需求,在此只提供一種這樣的思路。
通過(guò)代碼實(shí)現(xiàn)
先寫(xiě)一個(gè)刪除資源和角色綁定的接口:
/** * 根據(jù)資源id刪除相關(guān)的角色資源綁定數(shù)據(jù) * @param applicationIds 資源ids * @return 受影響行數(shù) */ int deleteByApplicationId(List<String> applicationIds);
<delete id="deleteByApplicationId"> UPDATE tc_role_application SET is_delete =1 WHERE application_id IN ( <foreach collection="list" item="id" separator=","> #{id} </foreach> ) AND is_delete = 0 </delete>
寫(xiě)一個(gè)刪除資源的接口:
int deleteByIds(@Param("list") List<String> var1, @Param("operator") String var2);
<delete id="deleteByIds"> update tc_application set is_delete = 1 , update_time=now() , operator = #{operator,jdbcType=VARCHAR} where id in ( <foreach collection="list" item="id" separator=","> #{id} </foreach> ) and is_delete = 0 </delete>
執(zhí)行刪除時(shí),先刪除子表數(shù)據(jù),后刪除父表數(shù)據(jù):
/** * 批量刪除資源并刪除其下相關(guān)的資源角色綁定數(shù)據(jù) * @param ids 資源ids */ @Transactional(rollbackFor = Exception.class) @Override public void deleteApplicationByIds(List<String> ids) { String user = TenancyContext.UserID.get(); //先刪除資源角色表中資源和角色綁定的數(shù)據(jù) roleApplicationService.deleteByApplicationId(ids); //刪除資源表數(shù)據(jù) this.deleteByIds(ids, user); }
總結(jié)
根據(jù)需求和實(shí)際選擇合適自己的方法。
到此這篇關(guān)于Mybatis 級(jí)聯(lián)刪除的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Mybatis 級(jí)聯(lián)刪除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)圖片上加文字水印(SpringMVC + Jsp)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)在圖片上加文字水印的方法,水印可以是圖片或者文字,操作方便,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05SSH框架網(wǎng)上商城項(xiàng)目第30戰(zhàn)之項(xiàng)目總結(jié)(附源碼下載地址)
這篇文章主要介紹了SSH框架網(wǎng)上商城項(xiàng)目第30戰(zhàn)之項(xiàng)目總結(jié),并附源碼下載地址,感興趣的小伙伴們可以參考一下2016-06-06springBoot 與neo4j的簡(jiǎn)單整合示例
這篇文章主要介紹了springBoot 與neo4j的簡(jiǎn)單整合示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01使用Spring的StopWatch實(shí)現(xiàn)代碼性能監(jiān)控的方法詳解
在開(kāi)發(fā)過(guò)程中,偶爾還是需要分析代碼的執(zhí)行時(shí)間,Spring 框架提供了一個(gè)方便的工具類(lèi) StopWatch,本文將介紹 StopWatch 的基本用法,并通過(guò)示例演示如何在項(xiàng)目中使用 StopWatch 進(jìn)行代碼性能監(jiān)控2023-12-12MyBatis-Plus中自動(dòng)填充功能的用法示例詳解
有些時(shí)候我們可能會(huì)有這樣的需求,插入或者更新數(shù)據(jù)時(shí),希望有些字段可以自動(dòng)填充數(shù)據(jù),比如密碼、version、注冊(cè)時(shí)默認(rèn)的用戶(hù)角色等,在MP中提供了這樣的功能,可以實(shí)現(xiàn)自動(dòng)填充功能,需要的朋友可以參考下2022-12-12Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(28)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-07-07Java反射獲取所有Controller和RestController類(lèi)的方法
這篇文章給大家分享了Java反射獲取所有Controller和RestController類(lèi)的方法,文中有詳細(xì)的代碼示例講解,具有一定的參考價(jià)值,需要的朋友可以參考下2023-08-08Idea連接數(shù)據(jù)庫(kù)并執(zhí)行SQL語(yǔ)句的方法示例
這篇文章主要介紹了Idea連接數(shù)據(jù)庫(kù)并執(zhí)行SQL語(yǔ)句的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Java中使用回調(diào)函數(shù)的方法實(shí)例
本文主要介紹了Java中使用回調(diào)函數(shù)的方法實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05