mybatis foreach標(biāo)簽的使用詳解
mybatis的foreach標(biāo)簽經(jīng)常用于遍歷集合,構(gòu)建in條件語句或者批量操作語句。
下面是foreach標(biāo)簽的各個(gè)屬性
| 屬性 | 描述 |
|---|---|
| collection | 表示迭代集合的名稱,可以使用@Param注解指定,如下圖 所示 該參數(shù)為必選 |
| item | 表示本次迭代獲取的元素,若collection為L(zhǎng)ist、Set或者數(shù)組,則表示其中的元素;若collection為map,則代表key-value的value,該參數(shù)為必選 |
| open | 表示該語句以什么開始,最常用的是左括弧'(',注意:mybatis會(huì)將該字符拼接到整體的sql語句之前,并且只拼接一次,該參數(shù)為可選項(xiàng) |
| close | 表示該語句以什么結(jié)束,最常用的是右括弧')',注意:mybatis會(huì)將該字符拼接到整體的sql語句之后,該參數(shù)為可選項(xiàng) |
| separator | mybatis會(huì)在每次迭代后給sql語句append上separator屬性指定的字符,該參數(shù)為可選項(xiàng) |
| index | 在list、Set和數(shù)組中,index表示當(dāng)前迭代的位置,在map中,index代指是元素的key,該參數(shù)是可選項(xiàng)。 |
假設(shè)接口中傳遞的list如下所示:
List<String> list = new ArrayList<>();
list.add("zhangsan");
list.add("lisi");
list.add("wangwu");
其中foreach標(biāo)簽配置如下:
<foreach collection="list" item="item" separator=",">
(#{item})
</foreach>
可以看到的是foreach標(biāo)簽指定了逗號(hào)作為分隔符,那么mybatis將會(huì)解析出foreach標(biāo)簽里面的內(nèi)容作為一個(gè)整體然后再其后面拼接上逗號(hào)分隔符,拼接后的過程如下所示:
('zhangsan') //第一步,迭代集合,獲取對(duì)應(yīng)的item,和外部的(),拼接形成('zhangsan')
('zhangsan'), //第二步,在之前的基礎(chǔ)上拼接上逗號(hào)分隔符
('zhangsan'),('lisi') //第三步,繼續(xù)迭代
('zhangsan'),('lisi'), //第四步,拼接逗號(hào)分隔符
('zhangsan'),('lisi'),('wangwu') //第五步,迭代集合并拼接,到此迭代結(jié)束
最終的結(jié)果為
('zhangsan'),('lisi'),('wangwu')
如果在foreach標(biāo)簽前面加上insert into table values,將會(huì)變形成
INSERT INTO user(user_name) VALUES('zhangsan'),('lisi'),('wangwu')
1
這種形式一般用于數(shù)據(jù)庫的批量增加。
如果將foreach配置修改如下,指定open屬性為左括弧,close屬性為右括?。?/p>
<foreach collection="list" item="item" open="(" separator="," close=")">
#{item}
</foreach>
那么拼接的過程如下所示
( //第一步,拼接open指定的開始字符
('zhangsan' //第二步,迭代集合,拼接對(duì)應(yīng)的item
('zhangsan', //第三步,拼接separator指定的分隔符
('zhangsan','lisi' //第四步,迭代集合,拼接對(duì)應(yīng)的item
('zhangsan','lisi', //第五步,拼接separator指定的分隔符
('zhangsan','lisi','wangwu' //第六步,迭代集合,拼接對(duì)應(yīng)的item
('zhangsan','lisi','wangwu') //第七步,拼接close指定的閉合字符
最終結(jié)果是:
('zhangsan','lisi','wangwu')
如果在foreach標(biāo)簽前面加上select … from table where … in ,將會(huì)變形成
SELECT * FROM user WHERE user_name in ('zhangsan','lisi','wangwu')
這種形式被用來構(gòu)建in條件語句。
如果collection類型為map,則index代表key,item代表對(duì)應(yīng)的value,可以這樣進(jìn)行批量插入:

其中Role實(shí)體類如下:

如果你想了解更多的關(guān)于mybaits標(biāo)簽的使用,請(qǐng)移步mybatis trim標(biāo)簽的使用
本文參考mybatis官方文檔
到此這篇關(guān)于mybatis foreach標(biāo)簽的使用詳解的文章就介紹到這了,更多相關(guān)mybatis foreach標(biāo)簽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring security登錄成功后跳轉(zhuǎn)回登錄前的頁面
這篇文章主要介紹了spring security登錄成功后跳轉(zhuǎn)回登錄前的頁面,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
java 中序列化NotSerializableException問題解決辦法
這篇文章主要介紹了java 中序列化NotSerializableException問題解決辦法的相關(guān)資料,這里對(duì)序列化問題進(jìn)行描述說明,并提供解決辦法,希望能幫助到大家,需要的朋友可以參考下2017-08-08
Springboot基礎(chǔ)之RedisUtils工具類
本文來說下RedisUtils工具類,主要介紹了整合Redis、MyBatis,封裝RedisUtils工具類等知識(shí),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好的幫助,需要的朋友可以參考下2021-05-05
Java解析xml文件和json轉(zhuǎn)換的方法(DOM4j解析)
相信大家都知道Java解析xml的方法有四種,每種方法都很不錯(cuò),今天通過本文給大家分享使用DOM4j進(jìn)行解析的方法,文章通過兩種方法給大家進(jìn)行解析,感興趣的朋友一起看看吧2021-08-08
Java基礎(chǔ)-Java基本數(shù)據(jù)類型
這篇文章主要介紹了Java基礎(chǔ)-Java基本數(shù)據(jù)類型,變量就是申請(qǐng)內(nèi)存來存儲(chǔ)值。也就是說,當(dāng)創(chuàng)建變量的時(shí)候,需要在內(nèi)存中申請(qǐng)空間,下面我們就來對(duì)Java基本數(shù)據(jù)類型作簡(jiǎn)單的介紹,需要的朋友可以參考一下2022-01-01
由淺到深帶你詳談Java實(shí)現(xiàn)數(shù)組擴(kuò)容的三種方式
這篇文章主要詳細(xì)介紹了Java實(shí)現(xiàn)數(shù)組擴(kuò)容的三種方式,新建一個(gè)數(shù)組,把原來數(shù)組的內(nèi)容搬到新數(shù)組中,使用system.arraycopy(),使用java.util.Arrays.copyOf()這三種方式,具有一定的參考價(jià)值,需要的朋友可以借鑒一下2023-06-06


所示 該參數(shù)為必選