mybatis批量更新数据

sql写法:

UPDATE user_table
        SET user_name= CASE id
            WHEN 1 THEN '张三'
            WHEN 2 THEN '李四'
            WHEN 3 THEN '王二'
        END
    WHERE id IN (1,2,3)

更新多个字段:

UPDATE user_table
        SET user_name= CASE id
            WHEN 1 THEN '张三'
            WHEN 2 THEN '李四'
            WHEN 3 THEN '王二'
        END,
        SET user_card= CASE id
            WHEN 1 THEN '001'
            WHEN 2 THEN '002'
            WHEN 3 THEN '003'
        END
    WHERE id IN (1,2,3)

WHERE id IN (1,2,3)不写也可以执行,在这里可以提升sql性能,避免全表扫描

mybatis写法:

mapper.java:

void updateUser(@Param("list") List<User> userList);

xml:

       <update id="updateUser" parameterType="java.util.List">
        update user_table
        <trim prefix="set" suffixOverrides=",">
            <trim prefix="user_name=case" suffix="end,">
                <foreach collection="list" item="item" index="index">
                     when id=#{item.id} then #{item.userName}
                </foreach>
            </trim>
        </trim>
        where id in
        <foreach collection="list" item="item" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </update>

更新多个字段

    <update id="updateUser" parameterType="java.util.List">
        update user_table
        <trim prefix="set" suffixOverrides=",">
            <trim prefix="user_name=case" suffix="end,">
                <foreach collection="list" item="item" index="index">
                     when id=#{item.id} then #{item.userName}
                </foreach>
            </trim>
            <trim prefix="user_card=case" suffix="end,">
                <foreach collection="list" item="item" index="index">
                    when id=#{item.id} then #{item.userCard}
                </foreach>
            </trim>
        </trim>
        where id in
        <foreach collection="list" item="item" open="(" separator="," close=")">
            #{item.id}
        </foreach>
    </update>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值