MyBatis 多個條件使用Map傳遞參數(shù)進行批量刪除方式
多個條件使用Map傳遞參數(shù)進行批量刪除
1、使用場景
因為項目需要針對資源文件(視頻、音頻、文檔),編輯時候可能出現(xiàn)以下3種情況:
實現(xiàn)的項目效果圖:

1.1、刪除多個已經(jīng)選擇的標簽(與本次文章相關(guān)內(nèi)容)
1.2、新增標簽(選擇已有標簽作為新增,輸入新的標簽作為新增的)
因為本業(yè)務(wù)場景之中與此文章相關(guān)的內(nèi)容 重點介紹一下如何,使用Map<String,Object> 參數(shù)傳遞過個參數(shù)進行批量刪除 資源標簽關(guān)系表記錄信息。
2、代碼實現(xiàn)
由于此功能需要在取消選擇當前資源標簽之中的,以前已經(jīng)選擇過的標簽,需要傳遞兩個參數(shù)進行刪除【資源標簽關(guān)系記錄表】之中的記錄,主要有資源id(resourceId),多個標簽的ids(deleteTagIdList)。具體代碼如下所示:
Java接口定義及MyBatis語句定義代碼
/**
* 刪除資源標簽關(guān)系表之中相關(guān)信息
* @param deleteTagRelationParams
* @return
*/
int deleteBatchEnclosureTagRelationList(Map<String, Object> deleteTagRelationParams);
<!-- 批量刪除 課程資源標簽 -->
<delete id="deleteBatchEnclosureTagRelationList" parameterType="hashmap">
delete from course_enclosure_tag where resource_id=#{resourceId} AND tag_id in
<foreach collection="deleteTagIdList" item="tagId" separator="," open="(" close=")">
#{tagId}
</foreach>
</delete>
具體業(yè)務(wù)操作Java代碼
if(deleteTagList.size()>0){
List<Long> deleteTagIdList=new ArrayList<Long>();
for(Map<String, Object> itemMap:deleteTagList) {
Long delTagId=Long.parseLong(itemMap.get("id").toString());
deleteTagIdList.add(delTagId);
}
Map<String, Object> deleteTagRelationParams=new HashMap<String, Object>();
deleteTagRelationParams.put("resourceId", courseEnclosure.getId());
deleteTagRelationParams.put("deleteTagIdList", deleteTagIdList);
deleteBatchEnclosureTagRelationList(deleteTagRelationParams);
}
注意事項:deleteTagIdList 參數(shù)的List<Long>類型一定要和接口函數(shù)之中的類型一致;本人定義接口參數(shù)
Long delTagId=Long.parseLong(itemMap.get("id").toString());
// 必須是Long定義類型List 如果使用long定義后端無法執(zhí)行的
long delTagId=Long.parseLong(itemMap.get("id").toString());
3、實現(xiàn)結(jié)果展現(xiàn)


MyBatis 多條件批量刪除的sql語句
今天在寫代碼的過程中,有一個批量刪除的需求,且這個刪除的條件是三個字段組成的聯(lián)合主鍵。
一開始我們新手可能會想到在service層使用for循環(huán)來多次調(diào)用mapper層的刪除方法,這樣雖然能夠?qū)崿F(xiàn)功能,但是消耗的系統(tǒng)資源很多,效率不高。
我也在網(wǎng)上找了找,發(fā)現(xiàn)這樣的例子很少
我把這次的代碼貼出來,僅供參考
代碼如下:
<delete id="deletePubPrintTmplComputers" parameterType="java.util.List">
delete from PUB_PRINT_TMPL_COMPUTER
<foreach collection="listData" item="item" separator="or" index="index">
<where>
<if test="item.tmplCode != null">
and TMPL_CODE = #{item.tmplCode, jdbcType=VARCHAR}
</if>
<if test="item.tmplSeq != null">
and TMPL_SEQ = #{item.tmplSeq, jdbcType=INTEGER}
</if>
<if test="item.computerCode != null">
and COMPUTER_CODE = #{item.computerCode,jdbcType=VARCHAR}
</if>
</where>
</foreach>
</delete>
這里是使用foreach語法進行批量操作,要特別注意的是,在每個if判斷中,條件語句末尾不要加逗號,不然會報錯,顯示sql命令未正確結(jié)束。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談Java list.remove( )方法需要注意的兩個坑
這篇文章主要介紹了淺談Java list.remove( )方法需要注意的兩個坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
Java的Flowable工作流之加簽轉(zhuǎn)簽詳解
這篇文章主要介紹了Java的Flowable工作流之加簽轉(zhuǎn)簽詳解,Flowable是一個開源的工作流引擎,它提供了一套強大的工具和功能,用于設(shè)計、執(zhí)行和管理各種類型的工作流程,需要的朋友可以參考下2023-11-11
基于SpringBoot實現(xiàn)Web應用的登錄與退出功能
登錄與退出功能作為 Web 應用中的基礎(chǔ)且重要的組成部分,直接關(guān)系到用戶的安全和隱私保護,所以本文給大家介紹了基于SpringBoot實現(xiàn)Web應用的登錄與退出功能,文中有詳細的代碼供大家參考,需要的朋友可以參考下2024-04-04
springboot 集成cas5.3 實現(xiàn)sso單點登錄詳細流程
SSO的定義是在多個應用系統(tǒng)中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統(tǒng)。單點登錄是目前比較流行的企業(yè)業(yè)務(wù)整合的解決方案之一,本文給大家介紹springboot 集成cas5.3 實現(xiàn)sso單點登錄功能,感興趣的朋友一起看看吧2021-10-10
微信開發(fā)準備第一步 Maven倉庫管理新建WEB項目
這篇文章主要為大家詳細介紹了微信開發(fā)準備第一步,Maven倉庫管理新建WEB項目,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
Easyui的combobox實現(xiàn)動態(tài)數(shù)據(jù)級聯(lián)效果
這篇文章主要介紹了Easyui的combobox實現(xiàn)動態(tài)數(shù)據(jù)級聯(lián)效果的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-06-06
Java優(yōu)雅的處理金錢問題(BigDecimal)
本文主要介紹了Java優(yōu)雅的處理金錢問題(BigDecimal),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06

