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

相关推荐
阿冰冰呀4 小时前
互联网大厂Java求职面试实录:谢飞机的“水货”之路
java·mybatis·dubbo·springboot·线程池·多线程·hashmap
Y0011123613 小时前
MyBatis
数据库·mybatis
zl_code_le15 小时前
浅谈MapperScan
mybatis
Boop_wu18 小时前
[Java EE进阶] 图书管理系统(2)
spring·java-ee·maven·mybatis·状态模式
小张小张爱学习19 小时前
Mybatis高频面试题
java·spring·mybatis
xuhaoyu_cpp_java19 小时前
Mybatis学习(四)
java·经验分享·笔记·学习·mybatis
invicinble1 天前
mybatis的核心机制沉淀
mybatis
m0_380113841 天前
补单系统搭建及源码分享
数据库·spring boot·mybatis
代码不加糖1 天前
0基础搭建前后端分离项目:实现菜单与界面左右布局
java·前端·javascript·mysql·elementui·mybatis
Boop_wu1 天前
[Java EE 进阶]Mybatis进阶(动态SQL)
java·数据库·maven·mybatis