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

其中Role實體類如下:

如果你想了解更多的關于mybaits標簽的使用,請移步mybatis trim標簽的使用
本文參考mybatis官方文檔
到此這篇關于mybatis foreach標簽的使用詳解的文章就介紹到這了,更多相關mybatis foreach標簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
mybatis返回list<Integer>時resultType寫Integer問題
這篇文章主要介紹了mybatis返回list<Integer>時resultType寫Integer問題,具有很好的參考價值,希望對大家有所幫助,2023-12-12
Spring中@EnableScheduling實現(xiàn)定時任務代碼實例
這篇文章主要介紹了Spring中@EnableScheduling實現(xiàn)定時任務代碼實例,@EnableScheduling 注解開啟定時任務功能,可以將多個方法寫在一個類,也可以分多個類寫,當然也可以將方法直接寫在上面ScheddulConfig類中,需要的朋友可以參考下2024-01-01
基于java file 文件操作operate file of java的應用
本篇文章介紹了,基于java file 文件操作operate file of java的應用。需要的朋友參考下2013-05-05
IDEA新建javaWeb以及Servlet簡單實現(xiàn)小結(jié)
這篇文章主要介紹了IDEA新建javaWeb以及Servlet簡單實現(xiàn)小結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
eclipse的web項目實現(xiàn)Javaweb購物車的方法
這篇文章主要介紹了eclipse的web項目實現(xiàn)Javaweb購物車的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10
Java多線程案例實戰(zhàn)之定時器的實現(xiàn)
在Java中可以使用多線程和定時器來實現(xiàn)定時任務,下面這篇文章主要給大家介紹了關于Java多線程案例之定時器實現(xiàn)的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-01-01


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