mybatis foreach Collection的List、Array、Map

本文详细解读Mybatis foreach标签的使用,包括其在遍历集合构建IN条件、参数类型匹配及不同场景下的collection属性设置。重点讲解了单参数List、Array、Map的处理方式和示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mybatis的foreach官方文档解释:对一个集合进行遍历,通常是在构建IN条件语句的时候使用。例如

<select id="selectPostIn" resultType="domain.blog.Post">
  SELECT *
  FROM POST P
  WHERE ID in
  <foreach item="item" index="index" collection="list" open="(" separator="," close=")">
        #{item}
  </foreach>
</select>

      foreach 元素的功能非常强大,它允许你指定一个集合,声明可以在元素体内使用的集合项(item)和索引(index)变量。它也允许你指定开头与结尾的字符串以及在迭代结果之间放置分隔符。这个元素是很智能的,因此它不会偶然地附加多余的分隔符。

注意:

     你可以将任何可迭代对象(如 List、Set 等)、Map 对象或者数组对象传递给 foreach 作为集合参数。当使用可迭代对象或者数组时,index 是当前迭代的次数,item 的值是本次迭代获取的元素。当使用 Map 对象(或者 Map.Entry 对象的集合)时,index 是键,item 是值。

foreach元素的属性主要有 item,index,collection,open,separator,close。

  1. item表示集合中每一个元素进行迭代时的别名,

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

  3. open表示该语句以什么开始,

  4. separator表示在每次进行迭代之间以什么符号作为分隔 符,

  5. close表示以什么结束。

       在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:

1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
2. 如果传入的是单参数且参数类型是一个Array数组的时候,collection的属性值为array
3. 如果传入的是Param修饰(@Param("ids") List<String>  ids)的时候,collection的属性值为ids
4. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可

        以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key 下面分别来看看上述三种情况的示例代码:

单参数List的类型:

 java:
 public int dynamicForeachList(List<String>  ids);

<!--错误写法:注意观察collection中参数的写法-->
<delete id="dynamicForeachList">
DELETE FROM s_user
WHERE id in
<foreach item="ids" collection="ids" open="(" separator=","close=")">
    #{ids}
</foreach>
</delete>

<!--正确写法-->
<delete id="dynamicForeachList">
DELETE FROM s_user
WHERE id in
<foreach item="ids" collection="list" open="(" separator=","close=")">
   #{ids}
</foreach>
</delete>

你也可以使用@Param(“ids”) 来指定参数名称这样就可以用自己的list名称了,如以下写法正确

  1. java:

  2. public int dynamicForeachList(@Param("ids")List<String> ids);

  3. sql:

  4. <delete id="dynamicForeachList">

  5. DELETE FROM s_user

  6. WHERE id in

  7. <foreach item="ids" collection="ids" open="(" separator=","close=")">

  8. #{ids}

  9. </foreach>

  10. </delete>

这样则正确。.

单参数array数组的类型:

同样注意collection属性的值:array

 
  1. java:

  2. public List dynamicForeachArray(int[] ids);

  3. sql:

  4. <select id="dynamicForeachArray" parameterType="java.util.ArrayList" resultType="Blog">

  5. select * from t_blog where id in

  6. <foreach collection="array" index="index" item="item" open="(" separator="," close=")">

  7. #{item}

  8. </foreach>

  9. </select>

自己把参数封装成Map的类型

  1. java

  2. public List dynamicForeachMap(Map params);

  3. sql

  4. <select id="dynamicForeachMap" parameterType="java.util.HashMap" resultType="Blog">

  5. select * from t_blog where title like "%"#{title}"%" and id in

  6. <foreach collection="ids" index="index" item="item" open="(" separator="," close=")">

  7. #{item}

  8. </foreach>

  9. </select>

注意:上面说的是传入参数是单个的List、Array、Map,如果是 传入的一个 对象或者 map, 其中有个属性是 list 或者array,那么colletion=“属性名”

java:
class example{
  List<String> subCodes;
}   

sql:
<!--传递的参数是对象-->
<if test="subCodes != null">
    and s.Code in
    <foreach collection="subCodes" item="subCode" open="(" close=")" separator=",">
        ${subCode}             
    </foreach>
</if>

其他例子:

1、List<Integer>  IntList   、 List<String> strList   集合中存的是基本类型的

  1. <select id="dynamicForeachTest" parameterType="java.util.List" resultMap="Users">

  2. select id,name from t_blog where id in

  3. <foreach collection="list" index="index" item="item" open="(" separator="," close=")">

  4. #{item}

  5. </foreach>

  6. </select>

      其中的传的参数是List集合所以collection 的值直接使用了list 来代替,而index 就是这个集合遍历的索引值,item 就是list当前索引位置的值 open 和close 成对出现,就是开始和结束的符号,而separator 就是分隔符。

2、List<Obect>  objList 、List<Users>  userList 引用类型的数据

  1. package soufun.com;

  2. public class Users {

  3. private int id;

  4. private String name;

  5. public int getId() {

  6. return id;

  7. }

  8. public void setId(int id) {

  9. this.id = id;

  10. }

  11. public String getName() {

  12. return name;

  13. }

  14. public void setName(String name) {

  15. this.name = name;

  16. }

  17. }

以这个类为例来看看:

 java:
 public int dynamicForeachList(List<Users>  uusers);

  1. <select id="dynamicForeachTest" parameterType="java.util.List" resultMap="Users">

  2. select id,name from t_blog where id in

  3. <foreach collection="list" index="index" item="item" open="(" separator="," close=")">

  4. #{item.id}

  5. </foreach>

  6. </select>

循环插入

  1. insert into t_blog(id,name) values

  2. <foreach collection="list" item="item" index="index" separator=",">

  3. (#{item.id},#{item.name})

  4. </foreach>

List 和array 是相似的。

下面我们看看map的遍历:

  1. HashMap<String,String> foreachMap= new HashMap<String,String>();

  2. map.put("name1", "www1");

  3. map.put("name2", "www2");

  4. map.put("name3", "www3");

  5. map.put("name4", "www4");

  6. map.put("name5", "www5");

  7. map.put("name6", "www6");


sqlSession.selectList(" getByMap", foreachMap);

  1. <select id="getByMap" resultMap="Users" >

  2. SELECT * FROM t_blog where

  3. <foreach collection="foreachMap" index="key" item="value" separator="or" >

  4. name=#{value}

  5. </foreach>

  6. </select>

其中的foreachMap 就是传递的Map集合 index 就是map的key item 就是map的value 

还可以使用如下的方式对map 进行遍历:

1、循环key:

  1. <foreach collection="condition.keys" item="k" separator="and">

  2. ${k} = #{k}

  3. </foreach>

2、循环values

  1. <foreach collection="condition.values" item="v" separator="and">

  2. ${v} = #{v}

  3. </foreach>

3、 循环获取key和值:

  1. <foreach collection="condition.keys" item="k" separator="and">

  2. <if test="null != condition[k]">

  3. ${k} = ${condition[k]}

  4. </if>

  5. </foreach>

${k} = #{condition[${k}]} 是不太好用在mybatis3.3下 修改成 ${k} = #{condition.${k}} 是好用的 

到这里都结束了,但还有个小事说一下,那就是in 的那个遍历,一般我们都是使用foreach 来组装 的但是有看到这样写的:

String  name ="'w1','w2','w3','w4'";

  1. <select id="getByMap" resultMap="Users">

  2. SELECT * FROM t_blog where name in (${name})

  3. </select>

这就是自己组装了 in的字符串,而没有使用mybatis的foreach 来组装其实是一样的。

转载自:https://blog.csdn.net/zzhongcy/article/details/102659104

### MyBatis `foreach` 标签与 `collection` 属性的使用方法 #### 1. 单参数为 List 类型的情况 当传递给 SQL 映射文件中的唯一参数是一个 `List` 集合时,`collection` 属性应设置为 `"list"`。这适用于大多数批量操作场景。 ```xml <select id="selectPostsByIds" resultType="domain.blog.Post"> SELECT * FROM POST P WHERE ID IN <foreach item="id" index="index" collection="list" open="(" separator="," close=")"> #{id} </foreach> </select> ``` 此配置允许通过传入一个整数列表来获取多篇帖子的信息[^5]。 #### 2. 参数为数组的情况 对于数组类型的输入参数,同样可以利用 `foreach` 实现循环遍历。此时需将 `collection` 设置为 `"array"` 来指示这是一个数组而非其他形式的数据结构。 ```xml <delete id="batchDeletePostsByArray" parameterType="int[]"> DELETE FROM POST WHERE ID IN <foreach item="id" index="idx" collection="array" open="(" separator="," close=")"> #{id} </foreach> </delete> ``` 这段代码展示了如何基于一组ID删除记录。 #### 3. 多个参数的情况下 当存在多个参数时,这些参数会被自动打包成一个 `Map` 对象。在这种情况下,`collection` 的值应当是指定集合所对应的键名。可以通过 `@Param` 注解显式定义键名称;如果不提供自定义名字,默认会按照位置顺序编号(如 param1, param2...)。 ```java // Java 方法签名示例 public List<Post> findPosts(@Param("ids") List<Integer> ids, @Param("status") String status); ``` 相应的 XML 映射如下: ```xml <select id="findPosts" resultMap="postResultMap"> SELECT * FROM POST p WHERE STATUS = #{status} AND ID IN <foreach item="id" index="i" collection="ids" open="(" separator="," close=")"> #{id} </foreach> </select> ``` 这里不仅实现了对特定状态的文章筛选,还支持按ID列表进一步过滤[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值