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

相关推荐
05大叔6 小时前
Mybatis-Plus
java·开发语言·mybatis
Predestination王瀞潞6 小时前
缓存机制:一二级缓存
spring·缓存·mybatis
Accerlator7 小时前
Redis 学习
redis·学习·mybatis
Predestination王瀞潞7 小时前
SQL 片段的提取与复用机制
java·sql·mybatis
jioulongzi8 小时前
mybatis映射mysql_json字段, 自定义typehandler返回null
mysql·json·mybatis
老赵全栈实战3 天前
【每日一技MyBatis trim标签核心用法
java·mybatis·orm
莫寒清14 天前
Mybatis的插件原理
面试·mybatis
莫寒清14 天前
MyBatis 中动态 SQL 的作用
面试·mybatis
吹晚风吧14 天前
实现一个mybatis插件,方便在开发中清楚的看出sql的执行及执行耗时
java·sql·mybatis
码云数智-大飞14 天前
像写 SQL 一样搜索:dbVisitor 如何用 MyBatis 范式颠覆 ElasticSearch 开发
sql·elasticsearch·mybatis