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

MyBatis 多個(gè)條件使用Map傳遞參數(shù)進(jìn)行批量刪除方式

 更新時(shí)間:2021年12月20日 14:28:26   作者:蜀山雪松  
這篇文章主要介紹了MyBatis 多個(gè)條件使用Map傳遞參數(shù)進(jìn)行批量刪除方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

多個(gè)條件使用Map傳遞參數(shù)進(jìn)行批量刪除

1、使用場(chǎng)景

因?yàn)轫?xiàng)目需要針對(duì)資源文件(視頻、音頻、文檔),編輯時(shí)候可能出現(xiàn)以下3種情況:

實(shí)現(xiàn)的項(xiàng)目效果圖:

1.1、刪除多個(gè)已經(jīng)選擇的標(biāo)簽(與本次文章相關(guān)內(nèi)容)

1.2、新增標(biāo)簽(選擇已有標(biāo)簽作為新增,輸入新的標(biāo)簽作為新增的)

因?yàn)楸緲I(yè)務(wù)場(chǎng)景之中與此文章相關(guān)的內(nèi)容 重點(diǎn)介紹一下如何,使用Map<String,Object> 參數(shù)傳遞過(guò)個(gè)參數(shù)進(jìn)行批量刪除 資源標(biāo)簽關(guān)系表記錄信息。

2、代碼實(shí)現(xiàn)

由于此功能需要在取消選擇當(dāng)前資源標(biāo)簽之中的,以前已經(jīng)選擇過(guò)的標(biāo)簽,需要傳遞兩個(gè)參數(shù)進(jìn)行刪除【資源標(biāo)簽關(guān)系記錄表】之中的記錄,主要有資源id(resourceId),多個(gè)標(biāo)簽的ids(deleteTagIdList)。具體代碼如下所示:

Java接口定義及MyBatis語(yǔ)句定義代碼

/**
 * 刪除資源標(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);
}

注意事項(xiàng):deleteTagIdList 參數(shù)的List<Long>類(lèi)型一定要和接口函數(shù)之中的類(lèi)型一致;本人定義接口參數(shù)

Long delTagId=Long.parseLong(itemMap.get("id").toString());
// 必須是Long定義類(lèi)型List 如果使用long定義后端無(wú)法執(zhí)行的
 
long delTagId=Long.parseLong(itemMap.get("id").toString());

3、實(shí)現(xiàn)結(jié)果展現(xiàn)

MyBatis 多條件批量刪除的sql語(yǔ)句

今天在寫(xiě)代碼的過(guò)程中,有一個(gè)批量刪除的需求,且這個(gè)刪除的條件是三個(gè)字段組成的聯(lián)合主鍵。

一開(kāi)始我們新手可能會(huì)想到在service層使用for循環(huán)來(lái)多次調(diào)用mapper層的刪除方法,這樣雖然能夠?qū)崿F(xiàn)功能,但是消耗的系統(tǒng)資源很多,效率不高。

我也在網(wǎng)上找了找,發(fā)現(xiàn)這樣的例子很少

我把這次的代碼貼出來(lái),僅供參考

代碼如下:

<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語(yǔ)法進(jìn)行批量操作,要特別注意的是,在每個(gè)if判斷中,條件語(yǔ)句末尾不要加逗號(hào),不然會(huì)報(bào)錯(cuò),顯示sql命令未正確結(jié)束。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Gradle build 報(bào)錯(cuò):Received status code 400 from server

    Gradle build 報(bào)錯(cuò):Received status code 400 from server

    這篇文章主要介紹了Gradle build 報(bào)錯(cuò):Received status code 400 from server,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • SpringCloud?hystrix斷路器與局部降級(jí)全面介紹

    SpringCloud?hystrix斷路器與局部降級(jí)全面介紹

    什么是服務(wù)降級(jí)?當(dāng)服務(wù)器壓力劇增的情況下,根據(jù)實(shí)際業(yè)務(wù)情況及流量,對(duì)一些服務(wù)和頁(yè)面有策略的不處理或換種簡(jiǎn)單的方式處理,從而釋放服務(wù)器資源以保證核心交易正常運(yùn)作或高效運(yùn)作
    2022-10-10
  • 集合嵌套之ArrayList嵌套ArrayList實(shí)例

    集合嵌套之ArrayList嵌套ArrayList實(shí)例

    下面小編就為大家?guī)?lái)一篇集合嵌套之ArrayList嵌套ArrayList實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 可視化定時(shí)任務(wù)quartz集成解析全過(guò)程

    可視化定時(shí)任務(wù)quartz集成解析全過(guò)程

    在開(kāi)發(fā)中有很多定時(shí)任務(wù)都不是寫(xiě)死的而是可以人為配置并且寫(xiě)到數(shù)據(jù)庫(kù)中的,下面這篇文章主要給大家介紹了關(guān)于可視化定時(shí)任務(wù)quartz集成解析的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Spring Boot整合Spring Security簡(jiǎn)單實(shí)現(xiàn)登入登出從零搭建教程

    Spring Boot整合Spring Security簡(jiǎn)單實(shí)現(xiàn)登入登出從零搭建教程

    這篇文章主要給大家介紹了關(guān)于Spring Boot整合Spring Security簡(jiǎn)單實(shí)現(xiàn)登入登出從零搭建的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧
    2018-09-09
  • Spring Security 實(shí)現(xiàn)短信驗(yàn)證碼登錄功能

    Spring Security 實(shí)現(xiàn)短信驗(yàn)證碼登錄功能

    這篇文章主要介紹了Spring Security 實(shí)現(xiàn)短信驗(yàn)證碼登錄功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Java 實(shí)戰(zhàn)項(xiàng)目錘煉之網(wǎng)上花店商城的實(shí)現(xiàn)流程

    Java 實(shí)戰(zhàn)項(xiàng)目錘煉之網(wǎng)上花店商城的實(shí)現(xiàn)流程

    讀萬(wàn)卷書(shū)不如行萬(wàn)里路,只學(xué)書(shū)上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+jsp+servlet+mysql+ajax實(shí)現(xiàn)一個(gè)網(wǎng)上花店商城系統(tǒng),大家可以在過(guò)程中查缺補(bǔ)漏,提升水平
    2021-11-11
  • IDEA快速搭建jsp項(xiàng)目的圖文教程

    IDEA快速搭建jsp項(xiàng)目的圖文教程

    這篇文章主要介紹了IDEA快速搭建jsp項(xiàng)目的圖文教程,本文分步驟通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • Java如何優(yōu)雅地關(guān)閉資源try-with-resource及其異常抑制

    Java如何優(yōu)雅地關(guān)閉資源try-with-resource及其異常抑制

    這篇文章主要介紹了Java如何優(yōu)雅地關(guān)閉資源try-with-resource及其異常抑制,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • 簡(jiǎn)述Java中throw-throws異常拋出

    簡(jiǎn)述Java中throw-throws異常拋出

    任何Java代碼都可以拋出異常,本文主要介紹了Java中throw-throws異常拋出,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-08-08

最新評(píng)論