MyBatis的foreach语句详解

foreach 属性介绍

foreach 用于迭代传入过来的参数。 
它的属性介绍分别是

  • collection:表示传入过来的参数的数据类型。该参数为必选。要做 foreach 的对象,作为入参时,List 对象默认用 list 代替作为键,数组对象有 array 代替作为键,Map 对象没有默认的键。当然在作为入参时可以使用 @Param(“keyName”) 来设置键,设置 keyName 后,list,array 将会失效。 除了入参这种情况外,还有一种作为参数对象的某个字段的时候。举个例子: 
    如果 User 有属性 List ids。入参是 User 对象,那么这个 collection = “ids” 如果 User 有属性 Ids ids;其中 Ids 是个对象,Ids 有个属性 List id;入参是 User 对象,那么 collection = “ids.id” 
    • 如果传入的是单参数且参数类型是一个 List 的时候,collection 属性值为 list
    • 如果传入的是单参数且参数类型是一个 array 数组的时候,collection 的属性值为 array
    • 如果传入的参数是多个的时候,我们就需要把它们封装成一个 Map 了,当然单参数也可以封装成 map。
  • item: 循环体中的具体对象。支持属性的点路径访问,如 item.age,item.info.details。具体说明:在 list 和数组中是其中的对象,在 map 中是 value,该参数为必选。(它是每一个元素进行迭代时的别名)
  • index:在 list 和数组中,index 是元素的序号;在 map 中,index 是元素的 key。
  • open:表示该语句以什么开始
  • close:表示该语句以什么结束
  • separator:表示在每次进行迭代之间以什么符号作为分隔符

介绍完属性之后,下面就进入实践。首先先来看一个简单到爆炸的表(表名:t_test_foreach)

这里写图片描述

(1)array

List<CarnumberAlarm> selectByDeviceIdAndTime(String[] ids);

xml配置:
    <if test="ids != null and ids.length > 0" >
        deviceId in 
        <foreach collection="array" open="(" separator="," close=")" item="item" index="index">
            #{item,jdbcType=VARCHAR}
        </foreach>
    </if>

(2)list

List<CarnumberAlarm> selectByDeviceIdAndTime(List<String> ids);

xml配置:
    <if test="ids != null and ids.size() > 0" >
        deviceId in 
        <foreach collection="list" open="(" separator="," close=")" item="item" index="index">
            #{item,jdbcType=VARCHAR}
        </foreach>
    </if>


   <!--list<String>-->
    <select id="getSocketNumList" parameterType="com.ex.application.model.dto.ScoketNumDTO" resultType="com.ex.application.model.dto.ScoketNumDTO">
        select sn,station_sn,socket_number,member_sn,state from socket where 1=1
        <if test="station_sn != null and station_sn != ''">
        station_sn = #{station_sn}
        </if>
        <if test="station_sns != null and station_sns.size() > 0" >
           and station_sn in
            <foreach collection="station_sns" open="(" separator="," close=")" item="item" index="index">
                #{item,jdbcType=VARCHAR}
            </foreach>
        </if>
    </select>

(3)map

List<CarnumberAlarm> selectByDeviceIdAndTime(Map<String, Object> params);

xml配置:
    <if test="ids != null and ids.size() > 0" >
        deviceId in 

        <!--collection属性是map.key,其它所有属性都是map.key-->
        <foreach collection="ids" open="(" separator="," close=")" item="item" index="index">
            #{item,jdbcType=VARCHAR}
        </foreach>
    </if>

单参数是 array /list类型

  <delete id="deleteByList">
        delete from goods where id in
        <foreach collection="list" open="(" separator="," close=")" item="haha">
            #{haha}
        </foreach>
        
    </delete>


//批量操作  (返回影响了几条数据的一个int 数字)
    public Integer deleteByList(List<GoodsInfo> list);

测试类

// ids = {1,2,3}
public List<User> testFindByArray(int[] ids) throws Exception {
    SqlSession sqlSession = getSession().openSession();
    userList = sqlSession.selectList(NameSpace + ".findByArray", ids);
    System.out.println(userList.toString());
    sqlSession.close();
    return userList;
}

mapper.xml

<!--这里的 item 值可以和传递过来的参数名不一样,在介绍属性的时候已经说过这是一个别名了。比如可以修改成如下代码:
    <foreach collection="array" item="id" index="index" open="(" close=")" separator=",">
        #{id}   <!--这里要和 item 值保持一致-->
    </foreach>
-->
<select id="findByArray" resultType="com.test.foreach.User">
    SELECT id,`name` FROM t_test_foreach WHERE id IN
    <foreach collection="array" item="ids" index="index" open="(" close=")" separator=",">
        #{ids}
    </foreach>
</select>

输出结果

DEBUG - ==>  Preparing: SELECT id,`name` FROM t_test_foreach WHERE id IN ( ? , ? , ? ) 
DEBUG - ==> Parameters: 1(Integer), 2(Integer), 3(Integer)
DEBUG - <==      Total: 3
[User{name='n1', id='1'}, User{name='n2', id='2'}, User{name='n3', id='3'}]

单参数是 List 类型

测试类

// List 元素有 1,3,5
public List<User> testFindByList(List<Integer> ids) throws Exception {
    SqlSession sqlSession = getSession().openSession();
    userList = sqlSession.selectList(NameSpace + ".findByList", ids);
    System.out.println(userList.toString());
    sqlSession.close();
    return userList;
}

mapper.xml

<select id="findByList" resultType="com.test.foreach.User">
    SELECT id,`name` FROM t_test_foreach WHERE id IN
    <foreach collection="list" item="ids" index="index" open="(" close=")" separator=",">
        #{ids}
    </foreach>
</select>

输出结果

DEBUG - ==>  Preparing: SELECT id,`name` FROM t_test_foreach WHERE id IN ( ? , ? , ? ) 
DEBUG - ==> Parameters: 1(Integer), 3(Integer), 5(Integer)
DEBUG - <==      Total: 3
[User{name='n1', id='1'}, User{name='n3', id='3'}, User{name='n5', id='5'}]

单参数是 Map 类型

测试类

// Map<String, Object> 中的元素有 int[] ids = {2, 4};map.put("ids", ids);
public List<User> testFindByMap(Map map) throws Exception {
    SqlSession sqlSession = getSession().openSession();
    System.out.println(map.toString());
    List<Object> objects = sqlSession.selectList(NameSpace + ".findByMap", map);
    System.out.println(objects.toString());
    sqlSession.close();
    return userList;
}

mapper.xml

<!--注意 collection 值是 ids,即要进行迭代的对象。觉得有点懵的伙伴可以回到最开始介绍 collection 属性那里看看,不要急-->
<select id="findByMap" resultType="com.test.foreach.User">
    SELECT id,`name` FROM t_test_foreach WHERE id IN
    <foreach collection="ids" item="id" index="index" open="(" close=")" separator=",">
        #{id}
    </foreach>
</select>

输出结果

DEBUG - ==>  Preparing: SELECT id,`name` FROM t_test_foreach WHERE id IN ( ? , ? ) 
DEBUG - ==> Parameters: 2(Integer), 4(Integer)
DEBUG - <==      Total: 2
[User{name='n2', id='2'}, User{name='n4', id='4'}]

多参数

这种情况在传参数时,一定要改用 Map 方式

测试类

public void testUpdateByParams(int[] ids,String name) throws Exception {
    SqlSession sqlSession = getSession().openSession();
    Map<String,Object> map = new HashMap<String, Object>();
    map.put("ids",ids); // ids = {1,2,4}
    map.put("name",name);// name = "updated"
    sqlSession.selectList(NameSpace + ".findByParams", map);
    sqlSession.close();
}

mapper.xml

<select id="findByParams">
    UPDATE t_test_foreach SET `name` = '#{name}' WHERE id IN
    <foreach collection="ids" item="item" index="index" open="(" close=")" separator=",">
        #{item}
    </foreach>
</select>

输出结果

DEBUG - ==>  Preparing: UPDATE t_test_foreach SET `name` = ? WHERE id IN ( ? , ? , ? ) 
DEBUG - ==> Parameters: updated(String), 1(Integer), 2(Integer), 4(Integer)

这里写图片描述

尊重他人劳动成果,转载请注明出处: 
mybatis foreach 属性及其三种使用情况_mybatis foreach object-CSDN博客

参考文章: 
Mybatis 示例之 foreach (上)_mybatis的foreach-CSDN博客 
MyBatis的foreach语句详解-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: MyBatis提供了`foreach`标签来遍历集合,可以将集合中的元素作为参数传入SQL语句中进行批量操作。 下面是`foreach`标签的基本语法: ```xml <foreach collection="list" item="item" index="index" open="(" separator="," close=")"> #{item} </foreach> ``` 其中,`collection`属性指定了要遍历的集合,`item`属性指定了遍历过程中每个元素的变量名,`index`属性指定了遍历过程中每个元素的索引名,`open`属性指定了遍历开始时的字符,`separator`属性指定了每个元素之间的分隔符,`close`属性指定了遍历结束时的字符。 例如,下面的代码展示了如何使用`foreach`标签将一个List中的元素作为参数传入SQL语句中进行批量插入: ```xml <insert id="batchInsert" parameterType="java.util.List"> INSERT INTO user(username, password, email) VALUES <foreach collection="list" item="item" index="index" separator=","> (#{item.username}, #{item.password}, #{item.email}) </foreach> </insert> ``` 在上述代码中,`parameterType`指定了方法参数的类型,`foreach`标签中的`list`属性指定了要遍历的List,`item`属性指定了每个元素的变量名为`item`,然后将List中的元素作为参数传入SQL语句中的`VALUES`子句中进行批量插入。 除了List之外,`foreach`标签还支持数组、Map等集合类型的遍历。具体用法可以参考MyBatis官方文档。 ### 回答2: Mybatisforeach是一个非常有用的功能,它可以用于在SQL语句中动态地生成多个参数。 使用foreach可以方便地处理一个集合中的元素,并将它们作为参数传递给SQL语句。我们可以使用它来解决一些常见的需求,例如批量插入、批量更新等。 在使用foreach时,我们需要指定要遍历的集合和要执行的SQL语句foreach会自动将集合中的元素按指定的方式进行拼接,并将拼接后的字符串作为SQL语句的一部分。 foreach支持多种遍历方式,例如使用index索引的方式、遍历Map的方式等。我们可以根据实际的需求选择合适的方式。 除了遍历集合,foreach还可以遍历数组。我们可以通过指定item属性来指定在遍历过程中,每个元素赋值给哪个变量。同时,我们还可以使用index属性指定索引值赋给哪个变量。 通过foreach,我们可以简化SQL语句的编写,减少重复代码的出现。它提供了一种灵活的方式,可以根据不同的情况生成不同的SQL语句,提高了代码的可维护性和可扩展性。 总之,mybatisforeach是一个非常实用的功能,它可以帮助我们轻松地处理集合中的元素,并将它们作为参数传递给SQL语句。它在数据操作中起到了很大的作用,提高了代码的效率和可读性。 ### 回答3: MyBatisforeach是一个强大且灵活的功能,用于在数据库查询中处理集合参数。通过foreach,我们可以将一个集合中的元素作为参数传递给SQL查询语句,从而实现批量操作或者查询。 在MyBatis中,foreach可以用于两种情况:批量插入和动态SQL查询。 对于批量插入,我们可以将一个集合中的元素插入到数据库的表中。通过foreach,我们可以迭代集合的每个元素,并将元素的属性值作为插入语句的参数传递给数据库。 对于动态SQL查询,我们可以根据集合的大小动态生成SQL语句,实现动态的查询操作。通过foreach,我们可以迭代集合的每个元素,并根据元素的属性值动态生成SQL查询条件,从而实现根据集合中的多个值查询数据库。 在使用foreach时,我们需要注意以下几点: 1. 集合参数必须是实现了Iterable接口的对象,如List、Set等。 2. foreach标签中的item属性指定集合元素的别名,index属性指定元素在集合中的索引。 3. foreach标签中的collection属性指定集合参数的名称。 4. foreach标签中的open、close和separator属性可以定制SQL语句的拼接规则。 5. foreach标签中可以使用动态标签(if、choose等)来实现复杂的条件判断。 总之,MyBatisforeach是一个非常方便的功能,可以简化批量操作和动态SQL查询的实现。我们可以根据实际需求灵活运用foreach,提高数据库操作的效率和灵活性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值