国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

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

MyBatis的foreach語句詳解

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

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

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

1. 如果傳入的是單參數且參數類型是一個List的時候,collection屬性值為list

2. 如果傳入的是單參數且參數類型是一個array數組的時候,collection的屬性值為array

3. 如果傳入的參數是多個的時候,我們就需要把它們封裝成一個Map了,當然單參數也可以封裝成map,實際上如果你在傳入參數的時候,在breast里面也是會把它封裝成一個Map的,map的key就是參數名,所以這個時候collection屬性值就是傳入的List或array對象在自己封裝的map里面的key

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

1.單參數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,對應的Mapper是這樣的

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

測試代碼:

 

?
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.單參數array數組的類型:

?
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,對應的Mapper代碼:

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

對應的測試代碼:

?
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.自己把參數封裝成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,是傳入的參數Map的key,對應的Mapper代碼:

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

對應測試代碼:

?
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語句詳解的相關知識,希望對大家有所幫助!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产永久免费在线观看 | 综合久久精品 | 国产精品美乳一区二区免费 | 国产精品久久久久久久久久免费 | 亚洲国产成人av | 久久加勒比 | 亚洲精品视频一区二区三区 | 国产激情网址 | 国产三级在线观看 | 免费一级毛片网站 | 欧美国产精品一区二区 | 久久久精品视频免费观看 | 亚洲国产精品一区二区久久 | 91精品国产欧美一区二区 | 精品亚洲一区二区 | 正在播放国产精品 | www.国产精| 一区二区三区四区精品 | 亚洲精品欧美 | 久草免费福利 | 免费精品人在线二线三线区别 | 国偷自产一区二区免费视频 | 狼人狠狠干 | 精品国产乱码久久久久夜 | 亚洲精品一区二区三区在线播放 | 久草福利资源 | 精品国产一区二区三区忘忧草 | 精品影院| 久久综合亚洲 | 国产精品久久久久桃色tv | 特黄特色的大片观看免费视频 | 欧美日韩精品一区二区三区蜜桃 | 色婷婷综合久久久中字幕精品久久 | 国产精品久久久久久久 | 日韩字幕在线 | 亚洲成人一区二区三区在线观看 | 免费在线a | 国产综合精品 | 不卡av电影在线观看 | 一级毛片免费视频 | 日韩成人影片 |