MyBatis 多個條件使用Map傳遞參數(shù)進(jìn)行批量刪除方式
多個條件使用Map傳遞參數(shù)進(jìn)行批量刪除
1、使用場景
因為項目需要針對資源文件(視頻、音頻、文檔),編輯時候可能出現(xiàn)以下3種情況:
實現(xiàn)的項目效果圖:
1.1、刪除多個已經(jīng)選擇的標(biāo)簽(與本次文章相關(guān)內(nèi)容)
1.2、新增標(biāo)簽(選擇已有標(biāo)簽作為新增,輸入新的標(biāo)簽作為新增的)
因為本業(yè)務(wù)場景之中與此文章相關(guān)的內(nèi)容 重點介紹一下如何,使用Map<String,Object> 參數(shù)傳遞過個參數(shù)進(jìn)行批量刪除 資源標(biāo)簽關(guān)系表記錄信息。
2、代碼實現(xiàn)
由于此功能需要在取消選擇當(dāng)前資源標(biāo)簽之中的,以前已經(jīng)選擇過的標(biāo)簽,需要傳遞兩個參數(shù)進(jìn)行刪除【資源標(biāo)簽關(guān)系記錄表】之中的記錄,主要有資源id(resourceId),多個標(biāo)簽的ids(deleteTagIdList)。具體代碼如下所示:
Java接口定義及MyBatis語句定義代碼
/** * 刪除資源標(biāo)簽關(guān)系表之中相關(guān)信息 * @param deleteTagRelationParams * @return */ int deleteBatchEnclosureTagRelationList(Map<String, Object> deleteTagRelationParams); <!-- 批量刪除 課程資源標(biāo)簽 --> <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語法進(jìn)行批量操作,要特別注意的是,在每個if判斷中,條件語句末尾不要加逗號,不然會報錯,顯示sql命令未正確結(jié)束。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Gradle build 報錯:Received status code 400 from server
這篇文章主要介紹了Gradle build 報錯:Received status code 400 from server,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07SpringCloud?hystrix斷路器與局部降級全面介紹
什么是服務(wù)降級?當(dāng)服務(wù)器壓力劇增的情況下,根據(jù)實際業(yè)務(wù)情況及流量,對一些服務(wù)和頁面有策略的不處理或換種簡單的方式處理,從而釋放服務(wù)器資源以保證核心交易正常運作或高效運作2022-10-10Spring Boot整合Spring Security簡單實現(xiàn)登入登出從零搭建教程
這篇文章主要給大家介紹了關(guān)于Spring Boot整合Spring Security簡單實現(xiàn)登入登出從零搭建的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧2018-09-09Spring Security 實現(xiàn)短信驗證碼登錄功能
這篇文章主要介紹了Spring Security 實現(xiàn)短信驗證碼登錄功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05Java 實戰(zhàn)項目錘煉之網(wǎng)上花店商城的實現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+jsp+servlet+mysql+ajax實現(xiàn)一個網(wǎng)上花店商城系統(tǒng),大家可以在過程中查缺補漏,提升水平2021-11-11Java如何優(yōu)雅地關(guān)閉資源try-with-resource及其異常抑制
這篇文章主要介紹了Java如何優(yōu)雅地關(guān)閉資源try-with-resource及其異常抑制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02