一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(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)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

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

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

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

3. 如果傳入的參數(shù)是多個的時候,我們就需要把它們封裝成一個Map了,當(dāng)然單參數(shù)也可以封裝成map,實際上如果你在傳入?yún)?shù)的時候,在breast里面也是會把它封裝成一個Map的,map的key就是參數(shù)名,所以這個時候collection屬性值就是傳入的List或array對象在自己封裝的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,對應(yīng)的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.單參數(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,對應(yīng)的Mapper代碼:

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

對應(yīng)的測試代碼:

?
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,對應(yīng)的Mapper代碼:

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

對應(yīng)測試代碼:

?
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)知識,希望對大家有所幫助!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 古代翁熄系小说辣文 | 欧美破苞合集 magnet | 美国高清xxxxx18 | 男人和女人日比 | 日本午夜视频 | 欧美日韩导航 | 欧美一区二区三区四区在线观看 | 久久re视频精品538在线 | 全黄h全肉细节文在线观看 全彩成人18h漫画 | 高h全肉动漫在线观看免费 高h辣h双处全是肉军婚 | 韩国三级在线观看 完整版 韩国三级视频网站 | 四虎在线免费 | 国产一成人精品福利网站 | 国产成人a v在线影院 | 精品欧美一区二区在线观看欧美熟 | 石原莉奈adn093店长未婚妻 | 色综合天天综合网看在线影院 | 国产一区日韩二区欧美三区 | 国产免费午夜高清 | 四虎在线观看 | 亚洲欧美日韩久久一区 | 羞羞麻豆国产精品1区2区3区 | 日本女人www | 四虎影视在线影院在线观看观看 | 亚洲欧美一区二区三区在饯 | 国产一区二区三区久久精品小说 | 日本视频中文字幕 | 亚洲精品第二页 | 欧美日韩成人在线视频 | 国产精品久久久久久久久久久久久久 | 狠狠色婷婷狠狠狠亚洲综合 | 亚洲精品视频在线 | 国产成人8x视频一区二区 | 丝袜老师好湿好紧我要进去了 | 高h短篇辣肉各种姿势bl | 国产精品一区二区三区久久 | 亚州第一页 | 欧美精品久久久亚洲 | 国产精品天天影视久久综合网 | 亚洲成人91 | 顶级欧美做受xxx000 |