激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - MyBatis的foreach語句詳解

MyBatis的foreach語句詳解

2020-05-21 11:40小蜜蜂 JAVA教程

這篇文章主要介紹了MyBatis的foreach語句詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

foreach的主要用在構(gòu)建in條件中,它可以在SQL語句中進(jìn)行迭代一個(gè)集合。foreach元素的屬性主要有 item,index,collection,open,separator,close。item表示集合中每一個(gè)元素進(jìn)行迭代時(shí)的別名,index指 定一個(gè)名字,用于表示在迭代過程中,每次迭代到的位置,open表示該語句以什么開始,separator表示在每次進(jìn)行迭代之間以什么符號(hào)作為分隔 符,close表示以什么結(jié)束,在使用foreach的時(shí)候最關(guān)鍵的也是最容易出錯(cuò)的就是collection屬性,該屬性是必須指定的,但是在不同情況 下,該屬性的值是不一樣的,主要有一下3種情況:

1. 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)List的時(shí)候,collection屬性值為list

2. 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)array數(shù)組的時(shí)候,collection的屬性值為array

3. 如果傳入的參數(shù)是多個(gè)的時(shí)候,我們就需要把它們封裝成一個(gè)Map了,當(dāng)然單參數(shù)也可以封裝成map,實(shí)際上如果你在傳入?yún)?shù)的時(shí)候,在breast里面也是會(huì)把它封裝成一個(gè)Map的,map的key就是參數(shù)名,所以這個(gè)時(shí)候collection屬性值就是傳入的List或array對(duì)象在自己封裝的map里面的key

下面分別來看看上述三種情況的示例代碼:

1.單參數(shù)List的類型:

?
1
2
3
4
5
6
<select id="dynamicForeachTest" resultType="Blog">
select * from t_blog where id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>

上述collection的值為list,對(duì)應(yīng)的Mapper是這樣的

?
1
public List<Blog> dynamicForeachTest(List<Integer> ids);

測(cè)試代碼:

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@Test
public void dynamicForeachTest() {
SqlSession session = Util.getSqlSessionFactory().openSession();
BlogMapper blogMapper = session.getMapper(BlogMapper.class);
List<Integer> ids = new ArrayList<Integer>();
ids.add(1);
ids.add(3);
ids.add(6);
List<Blog> blogs = blogMapper.dynamicForeachTest(ids);
for (Blog blog : blogs)
System.out.println(blog);
session.close();
}

2.單參數(shù)array數(shù)組的類型:

?
1
2
3
4
5
6
<select id="dynamicForeach2Test" resultType="Blog">
select * from t_blog where id in
<foreach collection="array" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>

上述collection為array,對(duì)應(yīng)的Mapper代碼:

?
1
public List<Blog> dynamicForeach2Test(int[] ids);

對(duì)應(yīng)的測(cè)試代碼:

?
1
2
3
4
5
6
7
8
9
10
@Test
public void dynamicForeach2Test() {
SqlSession session = Util.getSqlSessionFactory().openSession();
BlogMapper blogMapper = session.getMapper(BlogMapper.class);
int[] ids = new int[] {1,3,6,9};
List<Blog> blogs = blogMapper.dynamicForeach2Test(ids);
for (Blog blog : blogs)
System.out.println(blog);
session.close();
}

3.自己把參數(shù)封裝成Map的類型

?
1
2
3
4
5
6
<select id="dynamicForeach3Test" resultType="Blog">
select * from t_blog where title like "%"#{title}"%" and id in
<foreach collection="ids" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>

上述collection的值為ids,是傳入的參數(shù)Map的key,對(duì)應(yīng)的Mapper代碼:

?
1
public List<Blog> dynamicForeach3Test(Map<String, Object> params);

對(duì)應(yīng)測(cè)試代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
@Test
public void dynamicForeach3Test() {
SqlSession session = Util.getSqlSessionFactory().openSession();
BlogMapper blogMapper = session.getMapper(BlogMapper.class);
final List<Integer> ids = new ArrayList<Integer>();
ids.add(1);
ids.add(2);
ids.add(3);
ids.add(6);
ids.add(7);
ids.add(9);
Map<String, Object> params = new HashMap<String, Object>();
params.put("ids", ids);
params.put("title", "中國");
List<Blog> blogs = blogMapper.dynamicForeach3Test(params);
for (Blog blog : blogs)
System.out.println(blog);
session.close();
}

以上所述是小編給大家介紹的MyBatis的foreach語句詳解的相關(guān)知識(shí),希望對(duì)大家有所幫助!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色播视频在线播放 | 中文字幕在线观看视频一区 | 狠狠久久伊人中文字幕 | 成人精品aaaa网站 | 久久国产28 | 日本精品婷婷久久爽一下 | 成人毛片在线免费看 | 国产一区二区三区在线免费 | 国产精品一| 亚洲人成电影在线 | av电影免费播放 | 欧美日韩高清在线观看 | 国产精品久久久久久久娇妻 | 中国老女人一级毛片视频 | 成人福利视频在 | 精品一区二区三区在线观看视频 | 91精品国产日韩91久久久久久360 | www.精品在线 | 成人三区四区 | 青青草免费观看完整版高清 | 一级爱片| 久久99深爱久久99精品 | 国产一级免费在线视频 | 污黄视频在线播放 | 国产精品久久久久久久久久久久午夜 | 男女一边摸一边做羞羞视频免费 | 久久99综合| 久久免费视频3 | 成人三级电影网址 | 国产午夜精品一区二区三区免费 | 久久精品探花 | 操碰视频在线观看 | 久久精品欧美电影 | 国产视频软件在线 | 999精品久久久| 国产人成免费爽爽爽视频 | 国产免费一区二区三区在线能观看 | 成人毛片视频在线观看 | 成人国产精品一区二区毛片在线 | 请播放一级毛片 | 一边吃奶一边摸下娇喘 |