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

相关推荐
行走的搬运工1 天前
Spring Security_05
java·spring·mybatis
无级程序员1 天前
Mybatis中保证时间戳的一致性
mybatis
希望永不加班2 天前
SpringBoot 自定义 Starter:从零开发一个私有 Starter
java·spring boot·后端·spring·mybatis
未秃头的程序猿2 天前
💥 MyBatis 面试连环炮:从源码原理到实战避坑,彻底拿下 Offer 通关秘籍
后端·面试·mybatis
A_QXBlms2 天前
企微群发消息技术实现:定时任务+模板消息
java·mybatis·企业微信
huanmieyaoseng10032 天前
Mybatis常见面试题
java·开发语言·mybatis
希望永不加班2 天前
SpringBoot 自动配置类加载顺序与优先级
java·spring boot·后端·spring·mybatis
计算机学姐3 天前
基于SpringBoot的房屋交易系统
java·vue.js·spring boot·后端·spring·intellij-idea·mybatis
Rick19933 天前
spring boot和mybatis框架的设计思想和核心逻辑
spring boot·后端·mybatis
weixin_704266053 天前
读取Excel 和 显示预约人数
spring boot·mybatis·excel