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);
posted @ 2024-06-25 16:51  r涤生  阅读(34)  评论(0编辑  收藏  举报