Mybatis 級聯(lián)刪除的實現(xiàn)
需求描述
今日需求是刪除資源時同時刪除與該資源綁定的角色數(shù)據(jù),有兩張表,資源表、角色與資源綁定表,級聯(lián)刪除的時候有兩種方法:①建立表時直接建立約束,當(dāng)父表刪除數(shù)據(jù)時數(shù)據(jù)庫會自動去刪除子表中的數(shù)據(jù),②通過代碼實現(xiàn)級聯(lián)刪除,先刪除子表數(shù)據(jù),然后刪除父表中的數(shù)據(jù)。
通過數(shù)據(jù)庫實現(xiàn)
可以參考博文://www.dhdzp.com/article/88148.htm
這種方式假如我們要刪除父表的數(shù)據(jù),子表的數(shù)據(jù)就會被刪除,而我們的業(yè)務(wù)需求是表中是否刪除由is_delete字段來標(biāo)識,所以這種方式是可以實現(xiàn)級聯(lián)表刪除的,但是不符合我們的需求,在此只提供一種這樣的思路。
通過代碼實現(xiàn)
先寫一個刪除資源和角色綁定的接口:
/** * 根據(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>
寫一個刪除資源的接口:
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ù)據(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ù)需求和實際選擇合適自己的方法。
到此這篇關(guān)于Mybatis 級聯(lián)刪除的實現(xiàn)的文章就介紹到這了,更多相關(guān)Mybatis 級聯(lián)刪除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot3實現(xiàn)Gzip壓縮優(yōu)化的技術(shù)指南
隨著 Web 應(yīng)用的用戶量和數(shù)據(jù)量增加,網(wǎng)絡(luò)帶寬和頁面加載速度逐漸成為瓶頸,為了減少數(shù)據(jù)傳輸量,提高用戶體驗,我們可以使用 Gzip 壓縮 HTTP 響應(yīng),本文將介紹如何在 Spring Boot 3 中實現(xiàn) Gzip 壓縮優(yōu)化,需要的朋友可以參考下2025-04-04
IDEA 使用mybatis插件Free Mybatis plugin的步驟(推薦)
這篇文章主要介紹了IDEA 使用mybatis插件Free Mybatis plugin的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
Java數(shù)據(jù)結(jié)構(gòu)之單鏈表的實現(xiàn)與面試題匯總
由于順序表的插入刪除操作需要移動大量的元素,影響了運行效率,因此引入了線性表的鏈?zhǔn)酱鎯Α獑捂湵?。本文為大家介紹了單鏈表的實現(xiàn)與面試題匯總,感興趣的可以了解一下2022-10-10
MybatisPlus3.3.0沒有MybatisPlusInterceptor類問題的解決方法
項目使用的是mybatis-plus-extension3.3.0依賴,然后在我使用分頁插件的時候,發(fā)現(xiàn)無法導(dǎo)入MybatisPlusInterceptor類所以本文給大家介紹了MybatisPlus3.3.0沒有MybatisPlusInterceptor類問題的解決方法,需要的朋友可以參考下2023-12-12
解決DataInputStream?read不等于-1,socket文件傳輸只能傳輸一個文件無法傳輸多個問題
這篇文章主要介紹了解決DataInputStream?read不等于-1,socket文件傳輸只能傳輸一個文件無法傳輸多個問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
jsp+servlet實現(xiàn)簡單登錄頁面功能(附demo)
本文主要介紹了jsp+servlet實現(xiàn)簡單登錄頁面功能登錄成功跳轉(zhuǎn)新頁面,登錄失敗在原登錄界面提示登錄失敗信息,對初學(xué)者有一定的幫助,感興趣的可以了解一下2021-07-07

