国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Mybatis 級聯(lián)刪除的實現(xiàn)

瀏覽:39日期:2023-10-21 18:01:13

需求描述

今日需求是刪除資源時同時刪除與該資源綁定的角色數(shù)據(jù),有兩張表,資源表、角色與資源綁定表,級聯(lián)刪除的時候有兩種方法:①建立表時直接建立約束,當父表刪除數(shù)據(jù)時數(shù)據(jù)庫會自動去刪除子表中的數(shù)據(jù),②通過代碼實現(xiàn)級聯(lián)刪除,先刪除子表數(shù)據(jù),然后刪除父表中的數(shù)據(jù)。

通過數(shù)據(jù)庫實現(xiàn)

可以參考博文://www.jb51.net/article/88148.htm

這種方式假如我們要刪除父表的數(shù)據(jù),子表的數(shù)據(jù)就會被刪除,而我們的業(yè)務需求是表中是否刪除由is_delete字段來標識,所以這種方式是可以實現(xiàn)級聯(lián)表刪除的,但是不符合我們的需求,在此只提供一種這樣的思路。

通過代碼實現(xiàn)

先寫一個刪除資源和角色綁定的接口:

/** * 根據(jù)資源id刪除相關的角色資源綁定數(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ù):

/** * 批量刪除資源并刪除其下相關的資源角色綁定數(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ù)需求和實際選擇合適自己的方法。

到此這篇關于Mybatis 級聯(lián)刪除的實現(xiàn)的文章就介紹到這了,更多相關Mybatis 級聯(lián)刪除內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

相關文章:
主站蜘蛛池模板: 道真| 蓝田县| 鄢陵县| 卓资县| 磴口县| 西丰县| 阿尔山市| 中江县| 桐城市| 利辛县| 崇仁县| 根河市| 渭源县| 托克逊县| 镇远县| 西乌珠穆沁旗| 杭锦后旗| 交口县| 台前县| 九寨沟县| 嘉荫县| 抚远县| 灵宝市| 乌拉特前旗| 深水埗区| 乌兰浩特市| 临汾市| 政和县| 肇州县| 西盟| 崇州市| 永定县| 垫江县| 孟州市| 陆良县| 柳河县| 曲周县| 滨海县| 临颍县| 姜堰市| 房产|