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

相关推荐
yang_xiao_wu_2 小时前
springboot+mybatis面试题
spring boot·后端·mybatis
wh_xia_jun21 小时前
MyBatis Plus 中 xml 文件的一个例子
xml·mybatis
南极Ou21 小时前
Mybatis逆向工程详解(附源码文件)动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
xml·java·mybatis
生产队队长1 天前
项目练习:使用mybatis的foreach标签,实现union all的拼接语句
mybatis
加什么瓦1 天前
Mybatis
java·开发语言·mybatis
珹洺1 天前
MyBatis实战指南(七)MyBatis缓存机制
java·数据库·sql·安全·缓存·oracle·mybatis
結城1 天前
Spring Security如何拿到登录用户的信息
java·spring·mybatis
迢迢星万里灬2 天前
Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析
java·spring boot·spring·mybatis·spring mvc·面试指南
wowocpp2 天前
mybatis 关联映射---一对一关联映射
数据库·mybatis
谷哥的小弟2 天前
MyBatis注解开发的劣势与不足
mybatis·注解开发