Mysql
主页 > 数据库 > Mysql >

MySQL实现数据批量更新功能介绍

2023-12-20 | 佚名 | 点击:

根据不同条件批量更新同一值

这种场景直接通过update语句更新即可,如:

1

UPDATE t_sys_user SET `desc` = 'CaseWhen-0' WHERE id IN (1001,1002,1003);

根据不同条件更新不同值

循环遍历逐条更新

foreach多条更新:

1

2

3

4

5

6

7

8

9

10

11

<update id="updateForeach">

    <foreach collection="list" item="param" separator=";">

        UPDATE t_sys_user

        <set>

            <if test=" param.desc != null and param.desc != ''">

                `desc` = #{param.desc}

            </if>

        </set>

        WHERE id = #{param.id}

    </foreach>

</update>

case when 进行数据批量更新:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

<update id="updateBatchCaseWhen">

    UPDATE t_sys_user

    <set>

        <trim prefix="`DESC`= CASE id" suffix="END,">

            <foreach collection="list" item="param">

                <if test="param.id != null">

                    WHEN #{param.id} THEN #{param.desc}

                </if>

            </foreach>

        </trim>

<!--            <trim prefix="username = CASE id" suffix="END,">

            <foreach collection="list" item="param">

                <if test="param.username != null and param.username != ''">

                    WHEN #{param.} THEN #{param.username}

                </if>

            </foreach>

        </trim>  

-->

    </set>

    <where>

        id in

        <foreach collection="list" item="param" separator="," open="(" close=")">

            #{param.id}

        </foreach>

    </where>

</update>

原文链接:
相关文章
最新更新