MyBatis foreach的使用
foreach
动态 SQL 的一个常用的操作需求是对一个集合进行遍历,通常是在构建 IN 条件语句的时候。比如1:
<select id="getSonSonId" parameterType="java.lang.Integer" resultType="java.lang.Integer">
SELECT horse_id FROM horse_basic
WHERE horse_father_id IN
<foreach collection="sonIdList" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>
批量添加的时候。比如:
<insert id="insertImg" parameterType="com.xxx.platform.entity.SuggestionCustom">
INSERT INTO suggestion_img
(
suggestion_id,
img_path,
add_time
)
VALUES
<foreach collection="imgList" item="imgList" index="index" separator=",">
(
#{suggestion_id},
#{imgList},
#{suggestion_date}
)
</foreach>
</insert>
foreach 元素的功能非常强大,它允许你指定一个集合,声明可以在元素体内使用的集合项(item)和索引(index)变量。它也允许你指定开头与结尾的字符串以及在迭代结果之间放置分隔符。这个元素是很智能的,因此它不会偶然地附加多余的分隔符。
注:你可以将任何可迭代对象(如 List、Set 等)、Map 对象或者数组对象传递给 foreach 作为集合参数。当使用可迭代对象或者数组时,index 是当前迭代的次数,item 的值是本次迭代获取的元素。当使用 Map 对象(或者 Map.Entry 对象的集合)时,index 是键,item 是值。
foreach的属性2主要有 item,index,collection,open,separator,close。
- item表示集合中每一个元素进行迭代时的别名,
- index指 定一个名字,用于表示在迭代过程中,每次迭代到的位置,
- open表示该语句以什么开始,
- separator表示在每次进行迭代之间以什么符号作为分隔 符,
- close表示以什么结束。
在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:
- 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
- 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
- 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的。map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key