mybatis里的foreach语句

时间:2024-08-30 09:34:08

相信用了Mybatis的朋友们,都曾有一个疑惑,就是foreach是怎么用的,下面我就简单讲讲我的理解:

foreach主要用在SQL语句中迭代一个集合。foreach元素的属性主要由item,index,collection,open,separater,close。

下面我把foreach的这些属性详解一下:

item:集合中的每一个元素进行迭代时的别名

index:指定一个名字,用于表示在迭代过程中,每次迭代到的位置

open:表示该语句从以什么开始

separater:表示在每次进行迭代之间以什么符号作为分隔符

close:表示以什么结束

collection:在使用foreach的时候最关键的就是collection属性,该属性是必须指定的,在不同的情况下,该属性的值是不一样的,主要由以下3种情况:

1.如果传入的是单参数且参数是一个list时候,collection的属性值为list;

2.如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array;

3.如果传入的参数是多个的时候,我们就需要把他们封装成一个MAP了(单参数也可以封装成MAP,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个map的,map的key就是参数名,所以这个时候collection属性值就是传入的list或array对象在自己封装的一个map里面的key)

下面我就给大家一个截图演示:

mybatis里的foreach语句

collection=传入的map,图中的map为ids;

item="id",其中的ID要和下面的ID相同;

index随便填,循环中间用,分割