欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年06月15日 14:45:43   作者:wt_better  
這篇文章主要介紹了mybatis foreach標(biāo)簽的使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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

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

屬性 描述
collection 表示迭代集合的名稱,可以使用@Param注解指定,如下圖所示 該參數(shù)為必選
item 表示本次迭代獲取的元素,若collection為L(zhǎng)ist、Set或者數(shù)組,則表示其中的元素;若collection為map,則代表key-value的value,該參數(shù)為必選
open 表示該語(yǔ)句以什么開(kāi)始,最常用的是左括弧'(',注意:mybatis會(huì)將該字符拼接到整體的sql語(yǔ)句之前,并且只拼接一次,該參數(shù)為可選項(xiàng)
close 表示該語(yǔ)句以什么結(jié)束,最常用的是右括弧')',注意:mybatis會(huì)將該字符拼接到整體的sql語(yǔ)句之后,該參數(shù)為可選項(xiàng)
separator mybatis會(huì)在每次迭代后給sql語(yǔ)句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)分隔符,拼接后的過(guò)程如下所示:

('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ù)庫(kù)的批量增加。

如果將foreach配置修改如下,指定open屬性為左括弧,close屬性為右括?。?/p>

<foreach collection="list" item="item" open="(" separator="," close=")">
		#{item}
</foreach>

那么拼接的過(guò)程如下所示

(        //第一步,拼接open指定的開(kāi)始字符
('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')

這種形式被用來(lái)構(gòu)建in條件語(yǔ)句。

如果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)文章

  • springcloud配置ssh的問(wèn)題及解決方法

    springcloud配置ssh的問(wèn)題及解決方法

    這篇文章主要介紹了springcloud配置ssh,本文給大家介紹在配置過(guò)程中遇到的問(wèn)題及解決方法,通過(guò)結(jié)合實(shí)例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • mybatis返回list<Integer>時(shí)resultType寫Integer問(wèn)題

    mybatis返回list<Integer>時(shí)resultType寫Integer問(wèn)題

    這篇文章主要介紹了mybatis返回list<Integer>時(shí)resultType寫Integer問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,
    2023-12-12
  • SpringBoot整合BootStrap實(shí)戰(zhàn)

    SpringBoot整合BootStrap實(shí)戰(zhàn)

    這篇文章主要介紹了SpringBoot整合BootStrap實(shí)戰(zhàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java設(shè)計(jì)模式中的單一責(zé)任原則詳解

    Java設(shè)計(jì)模式中的單一責(zé)任原則詳解

    這篇文章主要介紹了Java設(shè)計(jì)模式中的單一責(zé)任原則詳解,應(yīng)該有且僅有一個(gè)原因引起類的變更,即單一指責(zé)原則要求一個(gè)借口或類只有一個(gè)原因引起變化,也就是一個(gè)接口或類只有一個(gè)職責(zé),它就負(fù)責(zé)一件事情,需要的朋友可以參考下
    2023-11-11
  • spring boot中各個(gè)版本的redis配置問(wèn)題詳析

    spring boot中各個(gè)版本的redis配置問(wèn)題詳析

    這篇文章主要給大家介紹了關(guān)于spring boot中各個(gè)版本的redis配置問(wèn)題的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • Spring中@EnableScheduling實(shí)現(xiàn)定時(shí)任務(wù)代碼實(shí)例

    Spring中@EnableScheduling實(shí)現(xiàn)定時(shí)任務(wù)代碼實(shí)例

    這篇文章主要介紹了Spring中@EnableScheduling實(shí)現(xiàn)定時(shí)任務(wù)代碼實(shí)例,@EnableScheduling 注解開(kāi)啟定時(shí)任務(wù)功能,可以將多個(gè)方法寫在一個(gè)類,也可以分多個(gè)類寫,當(dāng)然也可以將方法直接寫在上面ScheddulConfig類中,需要的朋友可以參考下
    2024-01-01
  • 基于java file 文件操作operate file of java的應(yīng)用

    基于java file 文件操作operate file of java的應(yīng)用

    本篇文章介紹了,基于java file 文件操作operate file of java的應(yīng)用。需要的朋友參考下
    2013-05-05
  • IDEA新建javaWeb以及Servlet簡(jiǎn)單實(shí)現(xiàn)小結(jié)

    IDEA新建javaWeb以及Servlet簡(jiǎn)單實(shí)現(xiàn)小結(jié)

    這篇文章主要介紹了IDEA新建javaWeb以及Servlet簡(jiǎn)單實(shí)現(xiàn)小結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11
  • eclipse的web項(xiàng)目實(shí)現(xiàn)Javaweb購(gòu)物車的方法

    eclipse的web項(xiàng)目實(shí)現(xiàn)Javaweb購(gòu)物車的方法

    這篇文章主要介紹了eclipse的web項(xiàng)目實(shí)現(xiàn)Javaweb購(gòu)物車的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Java多線程案例實(shí)戰(zhàn)之定時(shí)器的實(shí)現(xiàn)

    Java多線程案例實(shí)戰(zhàn)之定時(shí)器的實(shí)現(xiàn)

    在Java中可以使用多線程和定時(shí)器來(lái)實(shí)現(xiàn)定時(shí)任務(wù),下面這篇文章主要給大家介紹了關(guān)于Java多線程案例之定時(shí)器實(shí)現(xiàn)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01

最新評(píng)論