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

相关推荐
敖正炀18 小时前
MyBatis 性能调优:批处理、流式查询与 SQL 优化
mybatis
敖正炀18 小时前
初始化流程的完整串联:从 XML 到 SqlSessionFactory
mybatis
2301_7717172118 小时前
Spring Boot 自动配置核心注解
java·spring boot·mybatis
MegaDataFlowers19 小时前
使用MyBatisX快速生成CRUD
mybatis
敖正炀20 小时前
插件开发与拦截链——分页、脱敏、多租户实战
mybatis
敖正炀20 小时前
MyBatis 架构全解:SqlSession、Executor 与 StatementHandler
mybatis
敖正炀20 小时前
一级/二级缓存深度:生命周期、脏读与生产最佳实践
mybatis
空中海1 天前
MyBatis 基础认知、配置体系与核心映射
mybatis
空中海1 天前
05 MyBatis 架构设计、渐进式综合项目与专家题库
mybatis
空中海1 天前
03 MyBatis Spring Boot 集成、事务、测试与工程化体系
spring boot·后端·mybatis