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表示值对象。

相关推荐
爱丽_10 小时前
MyBatis事务管理与缓存机制详解
数据库·缓存·mybatis
雨中飘荡的记忆12 小时前
MyBatis SQL执行模块详解
数据库·sql·mybatis
_Aaron___12 小时前
MyBatis 连接缓慢问题排查与解决实战
mybatis
程序员侠客行13 小时前
Mybatis二级缓存实现详解
java·数据库·后端·架构·mybatis
好大的月亮19 小时前
mybatis在xml中使用OGNL取值简述
xml·mybatis
雨中飘荡的记忆19 小时前
MyBatis参数处理模块详解
java·mybatis
weixin_4250230020 小时前
多内网服务器公网中转通信方案(Spring Boot 2.7 + MyBatis Plus)
服务器·spring boot·mybatis
Light6021 小时前
MyBatis-Plus 全解:从高效 CRUD 到云原生数据层架构的艺术
spring boot·云原生·架构·mybatis·orm·代码生成·数据持久层
七夜zippoe21 小时前
MyBatis插件开发-实现SQL执行耗时监控
java·sql·mybatis·springboot·责任链
黄昏恋慕黎明21 小时前
快速上手mybatis(一)
java·数据库·mybatis