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

相关推荐
存在的五月雨7 小时前
MyBatis 中,#{} 和 ${}的区别
mybatis
mqiqe15 小时前
面试题-MyBatis 面试篇
java·面试·mybatis
kuonyuma15 小时前
MyBatis入门·注解操作
java·spring boot·mysql·spring·mybatis
SuperArc19992 天前
SpringBoot+Slf4j+Log4j2+mybatis 日志整合
spring boot·mybatis·log4j2·slf4j·日志整合
可乐ea2 天前
【Spring Boot + MyBatis|第4篇】MyBatis 动态 SQL:if、where、foreach 使用详解
java·spring boot·后端·sql·mybatis
一条泥憨鱼2 天前
苍穹外卖【day5|Redis与店铺营业状态设置】
java·后端·mybatis·苍穹外卖
来杯@Java2 天前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
我是唐青枫3 天前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
碎碎念_4924 天前
SpringBoot和MyBatis框架·速通版
spring boot·后端·mybatis
唐青枫4 天前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis