当前位置: 首页 > news >正文

mybatis-动态sql语句-<foreach>

循环遍历集合/数组,把集合元素拼接成sql片段,

动态处理多个参数的场景

就比如:简单场景的:构建IN条件、批量查询用户列表、一次插入多个用户,多对多关联表等等

属性

属性作用
collection要遍历的集合/数组/Map的key
item当前元素的别名:比如遍历users的每个元素的别名是user
separator元素之间的分隔符(IN条件会用“,”隔开)
open开头拼接(In条件开头用加"(")
close结尾拼接(In条件结尾用加")")

collection

  1. 传入List集合:例如List<Integer> ids : 那就是 collection="list"
  2. 传入数组:例如Integer[] ids:那就是 collection="array"
  3. 传入Map:例如Map<String,List> map ,其中key是"ids",value是具体的id集合,那collection="ids"——填 Map的key值
  4. 如果用@Param注解指定参数名了
List<User> getAllByIds (@Param("ids") List<Integer> ids)

那就用@param注解里面的名字

例子(一看就懂)

  • 构建IN条件(查询多个id的用户)

List<User> selectByIds(@Param("ids") List<Integer> idList);
<select id="selectByIds" resultType="com.example.User"> SELECT * FROM user WHERE id IN <!-- 循环拼接 (1,2,3) --> <foreach collection="ids" item="id" separator="," open="(" close=")"> #{id} <!-- 这里的id是item指定的别名,对应集合中的每个元素 --> </foreach> </select>

最终生成的sql语句就是 (如果idList=[1,2,3])

SELECT * FROM user WHERE id IN (1,2,3)
  • 批量插入
int InsertUsers(@Param("users") List<User> userList);
<insert id="InsertUsers"> INSERT INTO user (name, age) VALUES <!-- 循环拼接 (name1,age1),(name2,age2) --> <foreach collection="users" item="user" separator=","> (#{user.name}, #{user.age}) <!-- user是User对象别名,可直接取属性 --> </foreach> </insert>

最终生成的sql (如果userList有两个用户)

INSERT INTO user (name, age) VALUES ('张三',20),('李四',22)
  • 批量插入角色-菜单关联关系

比如:给角色 ID=1 绑定菜单 ID=2、3、4,会一次性插入 3 条记录:(1,2)、(1,3)、(1,4),避免循环调用单条插入,效率更高。

int insertRoleMenu(Role role);//Role实体类里有roleId和menuId
<insert id="insertRoleMenu" parameterType="com.shenkong.entity.Role"> insert into t_role_menu(roleId, menuId) VALUES <foreach collection="menuIds" item="menuid" separator=","> (#{roleId, javaType=java.lang.Integer, jdbcType=INTEGER}, #{menuid, javaType=java.lang.Integer, jdbcType=INTEGER}) </foreach> </insert>

生成的sql语句

insert into t_role_menu(roleId, menuId) VALUES (1, 2), (1, 3), (1, 4)
http://www.cnnetsun.cn/news/95366.html

相关文章:

  • 基于PLC控制的四路抢答器设计
  • 鸿蒙 Flutter 全场景开发实战指南:从环境搭建到分布式应用落地(2025 最新版)
  • LobeChat销售话术优化建议生成
  • 11章 像素和顶点数据导出 - “Vega“ 7nm Instruction Set ArchitectureReference Guide
  • 15人团队,60天,1000万美金ARR:Lovable正在重新定义“软件开发”
  • TensorFlow调试报错看不懂?LobeChat帮你解读
  • 2026届秋招AI岗位狂潮:大厂招聘激增10倍,这份成功上岸攻略不容错过!
  • 1、掌握 Linux 脚本编程:从基础到高级应用
  • 3、Bash脚本编写:基础与进阶
  • C#教程(小部分)
  • HNU 编译系统 作业1
  • vue基于Springboot框架的写字楼危险品管理信息系统的设计和实现
  • LobeChat现场引导标识文案
  • Vue3使用pinia做全局状态管理的简单示例
  • 2025计算机能力竞赛暨城市联赛——算法编程赛道【秋季赛】(二)
  • 用户体验调研问卷:LobeChat设计有效题目
  • BONT-L肽有效成分:棕榈酰六肽-19 Palmitoyl Hexapeptide-19
  • 1、Linux网络管理与资源指南
  • 9、Linux 下 PPP 协议的深入解析与配置指南
  • 13、Linux网络重要特性全解析
  • 17、深入了解 Taylor UUCP:原理、配置与应用
  • 避开“入狱”陷阱:零基础网络安全入门实战指南与知识图谱
  • 基于深度学习的安防监控校园暴力行为检测算法研究
  • 基于STM32单片机的智能家居系统设计
  • 14、Red Hat Linux实用应用指南
  • 零基础学网络安全?入门前必看的3大认知误区与5个关键准备
  • 21、红帽Linux安全与故障排除全攻略
  • 基于微信小程序的校园电子图书馆系统毕业设计
  • 创新首发!基于VMD+WDCNN-SENet的故障诊断模型
  • Python好不好学?