Mybatis 級聯刪除的實現
需求描述
今日需求是刪除資源時同時刪除與該資源綁定的角色數據,有兩張表,資源表、角色與資源綁定表,級聯刪除的時候有兩種方法:①建立表時直接建立約束,當父表刪除數據時數據庫會自動去刪除子表中的數據,②通過代碼實現級聯刪除,先刪除子表數據,然后刪除父表中的數據。
通過數據庫實現
可以參考博文://chabaoo.cn/article/88148.htm
這種方式假如我們要刪除父表的數據,子表的數據就會被刪除,而我們的業(yè)務需求是表中是否刪除由is_delete字段來標識,所以這種方式是可以實現級聯表刪除的,但是不符合我們的需求,在此只提供一種這樣的思路。
通過代碼實現
先寫一個刪除資源和角色綁定的接口:
/** * 根據資源id刪除相關的角色資源綁定數據 * @param applicationIds 資源ids * @return 受影響行數 */ 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í)行刪除時,先刪除子表數據,后刪除父表數據:
/**
* 批量刪除資源并刪除其下相關的資源角色綁定數據
* @param ids 資源ids
*/
@Transactional(rollbackFor = Exception.class)
@Override
public void deleteApplicationByIds(List<String> ids) {
String user = TenancyContext.UserID.get();
//先刪除資源角色表中資源和角色綁定的數據
roleApplicationService.deleteByApplicationId(ids);
//刪除資源表數據
this.deleteByIds(ids, user);
}
總結
根據需求和實際選擇合適自己的方法。
到此這篇關于Mybatis 級聯刪除的實現的文章就介紹到這了,更多相關Mybatis 級聯刪除內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java實現圖片上加文字水印(SpringMVC + Jsp)
這篇文章主要為大家詳細介紹了java實現在圖片上加文字水印的方法,水印可以是圖片或者文字,操作方便,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05
SSH框架網上商城項目第30戰(zhàn)之項目總結(附源碼下載地址)
這篇文章主要介紹了SSH框架網上商城項目第30戰(zhàn)之項目總結,并附源碼下載地址,感興趣的小伙伴們可以參考一下2016-06-06
使用Spring的StopWatch實現代碼性能監(jiān)控的方法詳解
在開發(fā)過程中,偶爾還是需要分析代碼的執(zhí)行時間,Spring 框架提供了一個方便的工具類 StopWatch,本文將介紹 StopWatch 的基本用法,并通過示例演示如何在項目中使用 StopWatch 進行代碼性能監(jiān)控2023-12-12
Java反射獲取所有Controller和RestController類的方法
這篇文章給大家分享了Java反射獲取所有Controller和RestController類的方法,文中有詳細的代碼示例講解,具有一定的參考價值,需要的朋友可以參考下2023-08-08

