Mybatis 动态 SQL - foreach

动态SQL的另一个常见需求是需要迭代一个集合,通常用于构建IN条件。例如:

XML 复制代码
<select id="selectPostIn" resultType="domain.blog.Post">
  SELECT *
  FROM POST P
  <where>
    <foreach item="item" index="index" collection="list"
        open="ID in (" separator="," close=")" nullable="true">
          #{item}
    </foreach>
  </where>
</select>

​<foreach>​元素非常强大,它允许您指定一个集合,并声明在元素体内可用的item和index变量。它还允许您指定打开和关闭字符串,并添加一个分隔符放置在迭代之间。该元素非常智能,不会意外地附加额外的分隔符。

注意:您可以将任何可迭代对象(例如List、Set等)、任何Map对象或数组对象作为 ​<foreach>​元素的collection参数传递。当使用可迭代对象或数组时,index表示当前迭代的次数,而value item表示在此迭代中检索到的元素。当使用Map(或包含Map.Entry对象的Collection)时,index表示键对象,item表示值对象。

相关推荐
weixin_425023007 小时前
Spring Boot + MyBatis Plus JOIN 分页多表查询项目文档
spring boot·后端·mybatis
undsky14 小时前
【RuoYi-Eggjs】:多数据库与 MyBatis 特性详解
node.js·mybatis·egg.js
柒.梧.15 小时前
MyBatis注解开发全解析:从基础CRUD到关联查询与延迟加载
mybatis
程序员侠客行16 小时前
Mybatis入门到精通 一
java·架构·mybatis
又是忙碌的一天17 小时前
Myvatis 动态查询及关联查询
java·数据库·mybatis
柒.梧.18 小时前
深度解析MyBatis缓存机制:从基础原理到实战配置
缓存·mybatis
一直都在57219 小时前
MyBatis缓存
缓存·mybatis
7澄119 小时前
MyBatis缓存详解:一级缓存、二级缓存与实战优化
缓存·mybatis·一级缓存
胡闹5420 小时前
MyBatis-Plus 更新字段为 null 为何失效?
java·数据库·mybatis
侠客行031721 小时前
Mybatis入门到精通 二
java·mybatis·源码阅读