mapper.xml中foreach里涉及when和then的含义

参考这个sql

<update id="updateDeptChildren" parameterType="java.util.List"> update sys_dept set ancestors =

<foreach collection="depts" item="item" index="index" separator=" " open="case dept_id" close="end"> when #{item.deptId} then #{item.ancestors} </foreach>

where dept_id in

<foreach collection="depts" item="item" index="index" separator="," open="(" close=")"> #{item.deptId} </foreach> </update>

上述示例是一个 MyBatis 的 `<update>` 元素的配置,用于更新 `sys_dept` 表中的记录。以下是对该配置的解释:

- `<update id="updateDeptChildren" parameterType="java.util.List">`:定义了一个名为 `updateDeptChildren` 的更新操作,输入参数类型为 `java.util.List`。

- `update sys_dept set ancestors =`:指定要更新的表和要更新的字段。

- `<foreach>` 元素用于循环遍历输入的 `depts` 列表,并根据其中的元素动态生成 SQL 语句。

  - 第一个 `<foreach>` 元素用于生成更新语句的 `case` 部分。它遍历 `depts` 列表中的每个元素,并根据元素的 `deptId` 和 `ancestors` 属性生成 `case` 语句。每个 `when` 子句表示当 `deptId` 匹配时,将 `ancestors` 值更新到 `sys_dept` 表的 `ancestors` 字段。

  - 第二个 `<foreach>` 元素用于生成更新语句的 `where` 部分。它遍历 `depts` 列表中的每个元素,并生成 `dept_id` 的 `IN` 条件,以将更新限制为指定的 `deptId` 值。

请注意,`<foreach>` 元素的属性说明如下:

- `collection`:指定要遍历的集合或数组。
- `item`:指定在遍历过程中当前元素的别名。
- `index`:指定在遍历过程中当前元素的索引(可选)。
- `separator`:指定在每次迭代之间添加的分隔符。
- `open`:指定在循环的开头添加的文本。
- `close`:指定在循环的结尾添加的文本。

通过以上配置,可以根据传入的 `depts` 列表中的元素动态生成更新语句,将指定的 `deptId` 的 `ancestors` 值更新到 `sys_dept` 表中,并通过 `deptId` 的条件限制更新的范围。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值