亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2020年11月02日 14:17:43   作者:環(huán)游記  
這篇文章主要介紹了Mybatis 級聯(lián)刪除的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

需求描述

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

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

     可以參考博文://chabaoo.cn/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);
  }

總結

     根據(jù)需求和實際選擇合適自己的方法。

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

相關文章

  • java實現(xiàn)圖片上加文字水印(SpringMVC + Jsp)

    java實現(xiàn)圖片上加文字水印(SpringMVC + Jsp)

    這篇文章主要為大家詳細介紹了java實現(xiàn)在圖片上加文字水印的方法,水印可以是圖片或者文字,操作方便,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05
  • SSH框架網(wǎng)上商城項目第30戰(zhàn)之項目總結(附源碼下載地址)

    SSH框架網(wǎng)上商城項目第30戰(zhàn)之項目總結(附源碼下載地址)

    這篇文章主要介紹了SSH框架網(wǎng)上商城項目第30戰(zhàn)之項目總結,并附源碼下載地址,感興趣的小伙伴們可以參考一下
    2016-06-06
  • springBoot 與neo4j的簡單整合示例

    springBoot 與neo4j的簡單整合示例

    這篇文章主要介紹了springBoot 與neo4j的簡單整合示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 使用Spring的StopWatch實現(xiàn)代碼性能監(jiān)控的方法詳解

    使用Spring的StopWatch實現(xiàn)代碼性能監(jiān)控的方法詳解

    在開發(fā)過程中,偶爾還是需要分析代碼的執(zhí)行時間,Spring 框架提供了一個方便的工具類 StopWatch,本文將介紹 StopWatch 的基本用法,并通過示例演示如何在項目中使用 StopWatch 進行代碼性能監(jiān)控
    2023-12-12
  • MyBatis-Plus中自動填充功能的用法示例詳解

    MyBatis-Plus中自動填充功能的用法示例詳解

    有些時候我們可能會有這樣的需求,插入或者更新數(shù)據(jù)時,希望有些字段可以自動填充數(shù)據(jù),比如密碼、version、注冊時默認的用戶角色等,在MP中提供了這樣的功能,可以實現(xiàn)自動填充功能,需要的朋友可以參考下
    2022-12-12
  • Java日常練習題,每天進步一點點(28)

    Java日常練習題,每天進步一點點(28)

    下面小編就為大家?guī)硪黄狫ava基礎的幾道練習題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-07-07
  • Java中異常處理之try和catch代碼塊的使用

    Java中異常處理之try和catch代碼塊的使用

    這篇文章主要介紹了Java中異常處理之try和catch代碼塊的使用,是Java入門學習中的基礎知識,需要的朋友可以參考下
    2015-09-09
  • Java反射獲取所有Controller和RestController類的方法

    Java反射獲取所有Controller和RestController類的方法

    這篇文章給大家分享了Java反射獲取所有Controller和RestController類的方法,文中有詳細的代碼示例講解,具有一定的參考價值,需要的朋友可以參考下
    2023-08-08
  • Idea連接數(shù)據(jù)庫并執(zhí)行SQL語句的方法示例

    Idea連接數(shù)據(jù)庫并執(zhí)行SQL語句的方法示例

    這篇文章主要介紹了Idea連接數(shù)據(jù)庫并執(zhí)行SQL語句的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Java中使用回調函數(shù)的方法實例

    Java中使用回調函數(shù)的方法實例

    本文主要介紹了Java中使用回調函數(shù)的方法實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05

最新評論