mybatis mapper.xml批量删除操作
在springboot + mybatis的项目里实现批量删除操作。
代码
xxxMapper.xml
:
...
<!-- 批量删除用户 -->
<delete id="deleteUsersByIds">
DELETE FROM users WHERE id IN
<foreach collection="list" item="id" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
...
解释:
<foreach collection="list" item="id" open="(" separator="," close=")">
:
- 使用
<foreach>
标签来遍历传入的 id 列表。 collection="list"
表示传入的参数是一个列表(可以是 List、Set 或数组)。item="id"
表示遍历时的每个元素将被称为 id。open="("
表示在循环开始时输出一个左括号。separator=","
表示每个元素之间用逗号分隔。close=")"
表示在循环结束时输出一个右括号。
假设我们传入的 list 是 [1, 2, 3, 4, 5],那么
<foreach collection="list" item="id" open="(" separator="," close=")">
#{id}
</foreach>
这行代码生成的SQL片段为:
(1, 2, 3, 4, 5)
生成的完整的SQL语句为:
DELETE FROM users
WHERE id IN (1, 2, 3, 4, 5);
rds_blogs
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?