亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

mybatis foreach標簽的使用詳解

瀏覽:120日期:2023-10-24 07:19:26

mybatis的foreach標簽經常用于遍歷集合,構建in條件語句或者批量操作語句。

下面是foreach標簽的各個屬性

屬性 描述 collection 表示迭代集合的名稱,可以使用@Param注解指定,如下圖mybatis foreach標簽的使用詳解所示 該參數為必選 item 表示本次迭代獲取的元素,若collection為List、Set或者數組,則表示其中的元素;若collection為map,則代表key-value的value,該參數為必選 open 表示該語句以什么開始,最常用的是左括弧’(’,注意:mybatis會將該字符拼接到整體的sql語句之前,并且只拼接一次,該參數為可選項 close 表示該語句以什么結束,最常用的是右括弧’)’,注意:mybatis會將該字符拼接到整體的sql語句之后,該參數為可選項 separator mybatis會在每次迭代后給sql語句append上separator屬性指定的字符,該參數為可選項 index 在list、Set和數組中,index表示當前迭代的位置,在map中,index代指是元素的key,該參數是可選項。

假設接口中傳遞的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標簽里面的內容作為一個整體然后再其后面拼接上逗號分隔符,拼接后的過程如下所示:

(’zhangsan’) //第一步,迭代集合,獲取對應的item,和外部的(),拼接形成(’zhangsan’)(’zhangsan’), //第二步,在之前的基礎上拼接上逗號分隔符(’zhangsan’),(’lisi’) //第三步,繼續迭代(’zhangsan’),(’lisi’), //第四步,拼接逗號分隔符(’zhangsan’),(’lisi’),(’wangwu’) //第五步,迭代集合并拼接,到此迭代結束

最終的結果為

(’zhangsan’),(’lisi’),(’wangwu’)

如果在foreach標簽前面加上insert into table values,將會變形成

INSERT INTO user(user_name) VALUES(’zhangsan’),(’lisi’),(’wangwu’) 1

這種形式一般用于數據庫的批量增加。

如果將foreach配置修改如下,指定open屬性為左括弧,close屬性為右括弧:

<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指定的閉合字符

最終結果是:

(’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,可以這樣進行批量插入:

mybatis foreach標簽的使用詳解

其中Role實體類如下:

mybatis foreach標簽的使用詳解

如果你想了解更多的關于mybaits標簽的使用,請移步mybatis trim標簽的使用本文參考mybatis官方文檔

到此這篇關于mybatis foreach標簽的使用詳解的文章就介紹到這了,更多相關mybatis foreach標簽內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 国产欧美日韩免费一区二区 | 亚洲欧美国产精品第1页 | 亚洲毛片视频 | www亚洲视频 | 96福利| 免费鲁丝片一级观看 | xxxxx日本护士xxxhd | 在线观看色 | 国产香蕉精品视频 | 俄国特级毛片www免 俄罗斯14一18处交 | 大陆一级毛片免费视频观看 | 91精品国产欧美一区二区 | 一区二区在线观看高清 | 成人福利免费在线观看 | 欧美一级特黄一片免费 | 日本亚洲成高清一区二区三区 | 国产精品久久久久一区二区 | 妞干网中文字幕 | 国产成人a大片大片在线播放 | 大伊人青草狠狠久久 | 亚洲国产三级 | 日本亚洲黄色片 | 久久香蕉精品视频 | 青青伊人网 | 香蕉视频黄在线观看 | 国产精品免费一区二区区 | 国产vvv在线观看 | 野外三级国产在线观看 | 好吊妞gao988在线播放 | 久久久久久久999 | 日韩精品在线视频 | 一级黄色毛片免费看 | 手机国产日韩高清免费看片 | 色黄网站aaaaaa级毛片 | 精品国产人成亚洲区 | 国产亚洲精品一区在线播 | 一级片黑人 | 精品女同一区二区三区免费站 | 亚洲精品99久久一区二区三区 | 久久精品国产一区二区三区日韩 | 大美女香蕉丽人视频网站 |