Mybatis 如何批量刪除數(shù)據(jù)的實(shí)現(xiàn)示例
本期以最常用的根據(jù)id批量刪除數(shù)據(jù)為例:
接口設(shè)計(jì)1:List類型單參數(shù)
Integer deleteByIds(List<Integer> ids);
接口設(shè)計(jì)2:Array數(shù)組類型單參數(shù)
Integer deleteByIds(Integer[] ids);
接口設(shè)計(jì)3:可變長(zhǎng)度參數(shù)
Integer deleteByIds(Integer... ids);
此以接口2為例子mapper.xml配置如下:
<delete id="deleteByIds">
DELETE FROM t_user WHERE id IN (
<foreach collection="array" item="id" separator=",">
#{id}
</foreach>
)
</delete>
關(guān)于<foreach>節(jié)點(diǎn)的配置說明:
collection:需要被遍歷的對(duì)象,當(dāng)抽象方法的參數(shù)只有1個(gè)且沒有添加@Param注解時(shí),如果參數(shù)類型是List集合,則取值為list,如果參數(shù)類型是數(shù)組,則取值為array;當(dāng)抽象方法的參數(shù)超過1個(gè),就一定添加了@Param注解,則取值為@Param注解配置的參數(shù)值;
如下圖接口所示:

item:遍歷過程中的每一個(gè)元素?cái)?shù)據(jù),當(dāng)前屬性可以自定義值表示元素?cái)?shù)據(jù)的名稱,在<foreach>節(jié)點(diǎn)的子級(jí),使用#{}占位符時(shí),就可以使用這個(gè)名稱來表示數(shù)據(jù);
separator:遍歷生成的代碼片段中,各元素?cái)?shù)據(jù)之間的分隔符號(hào);
open / close:遍歷生成的代碼片段的最左側(cè)字符串/最右側(cè)字符串。
補(bǔ)充知識(shí)點(diǎn):關(guān)于#{}和${}格式的占位符
MyBatis允許在配置SQL語句時(shí)使用#{}和${}這2種格式的占位符來表示參數(shù)值。
簡(jiǎn)單原則:在原本使用JDBC技術(shù)編程時(shí),編寫SQL語句時(shí)可以寫問號(hào)(?)的位置,都使用#{}格式的占位符,不可以寫問號(hào)的位置,必須使用${}格式的占位符!
使用#{}格式的占位符,只能表示某個(gè)值!MyBatis在處理時(shí),會(huì)通過預(yù)編譯的方式進(jìn)行處理,即:先使用問號(hào)對(duì)占位符表示的值進(jìn)行占位,并將整個(gè)SQL語句交由MySQL進(jìn)行編譯相關(guān)的處理(包括詞法分析、語義分析、編譯),當(dāng)編譯完成后,再將值代入到編譯成功的SQL語句中一并執(zhí)行。簡(jiǎn)單來說,使用#{}格式的占位符時(shí),最終處理機(jī)制是使用了預(yù)編譯的!所以,使用這種格式的占位符時(shí),在編寫SQL時(shí)不需要關(guān)心值的數(shù)據(jù)類型的問題,并且,不存在SQL注入的風(fēng)險(xiǎn)!
使用${}格式的占位符,可以表示SQL語句中的任意片段!MyBatis在處理時(shí),會(huì)先將${}格式占位符對(duì)應(yīng)的值拼接到SQL語句中,然后再將SQL語句交由MySQL進(jìn)行編譯相關(guān)處理,也就是說,${}格式占位符的值在編譯之前就已經(jīng)代入到SQL語句中了!很顯然,在處理${}格式的占位符時(shí),沒有(也不可能)使用預(yù)編譯!所以,使用這種格式的占位符時(shí),需要自行在SQL語句中考慮數(shù)據(jù)類型的問題,例如字符串類型的值需要使用一對(duì)單引號(hào)框??!另外,還存在SQL注入的風(fēng)險(xiǎn)!
到此這篇關(guān)于Mybatis 如何批量刪除數(shù)據(jù)的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Mybatis 批量刪除數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Jenkins自動(dòng)化構(gòu)建工具進(jìn)行敏捷開發(fā)
這篇文章主要為大家介紹了使用Jenkins自動(dòng)化構(gòu)建工具進(jìn)行敏捷開發(fā),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04
springboot實(shí)現(xiàn)后臺(tái)上傳圖片(工具類)
這篇文章主要為大家詳細(xì)介紹了springboot實(shí)現(xiàn)后臺(tái)上傳圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
使用Spring RestTemplate 詳解實(shí)踐使用及拓展增強(qiáng)
這篇文章主要介紹了使用Spring RestTemplate 詳解實(shí)踐使用及拓展增強(qiáng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
SpringBoot中DTO/VO/Entity相互轉(zhuǎn)換詳解
在我們平時(shí)開發(fā)中,dto、vo、entity之間的相互轉(zhuǎn)換是很頻繁的操作,這篇文章就簡(jiǎn)單記錄一下在平時(shí)開發(fā)中SpringBoot的轉(zhuǎn)換方法,希望對(duì)大家有所幫助2025-01-01
詳解Spring Boot使用系統(tǒng)參數(shù)表提升系統(tǒng)的靈活性
Spring Boot項(xiàng)目中常有一些相對(duì)穩(wěn)定的參數(shù)設(shè)置項(xiàng),其作用范圍是系統(tǒng)級(jí)的或模塊級(jí)的,這些參數(shù)稱為系統(tǒng)參數(shù)。這些變量以參數(shù)形式進(jìn)行配置,從而提高變動(dòng)和擴(kuò)展的靈活性,保持代碼的穩(wěn)定性2021-06-06

