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

您的位置:首頁技術(shù)文章
文章詳情頁

mybatis foreach標(biāo)簽的使用詳解

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

mybatis的foreach標(biāo)簽經(jīng)常用于遍歷集合,構(gòu)建in條件語句或者批量操作語句。

下面是foreach標(biāo)簽的各個(gè)屬性

屬性 描述 collection 表示迭代集合的名稱,可以使用@Param注解指定,如下圖mybatis foreach標(biāo)簽的使用詳解所示 該參數(shù)為必選 item 表示本次迭代獲取的元素,若collection為List、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屬性為右括弧:

<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)行批量插入:

mybatis foreach標(biāo)簽的使用詳解

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

mybatis foreach標(biāo)簽的使用詳解

如果你想了解更多的關(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 国语对白清晰好大好白在线 | 337d欧美人体大胆瓣开下面 | 精品特级一级毛片免费观看 | 鲁大师视频在线www观看 | 91久久老司机福利精品网 | 黑人巨大解禁久久中文字幕 | 国产96精品| 日韩国产一区二区 | 国产亚洲在线观看 | 福利在线免费视频 | 黄色一级片黄色一级片 | 国产亚洲人成网站在线观看不卡 | 66av99精品福利视频在线 | 国产乱熟肥女视频网站 | 欧美色片在线观看 | 一级黄色录像大片 | 成人在线免费看 | 国产精品久久久久激情影院 | 青草视频在线观看免费网站 | 国产美女视频国产视视频 | 韩日免费视频 | 国产精品短视频免费观看 | 午夜久久久久久网站 | 国产欧美一区二区精品性色99 | 99久久99这里只有免费费精品 | 国产在线播放一区二区 | 欧美日韩国产深夜福利视频 | 手机毛片在线 | 亚洲精品日本高清中文字幕 | 色九九亚洲偷偷动态图 | 久久中文字幕一区二区三区 | 美国黄色毛片一级 | 韩国免费人成在线观看网站 | 97久视频精品视频在线老司机 | 中国黄色免费 | 内地自拍 | 久久国产影视免费精品 | 久久久久久久国产精品影院 | 久久精品视频2 | 久久精品国产免费观看99 | 国产欧美日韩在线观看精品 |