Mybatis 根据不同id进行批量更新

Mybatis批量更新

  • 应用环境
    Mybatis、Mysql

  • 实体类

    public class ServiceGroup {
    
        private Integer id;
    
        private String services;
    
        public Integer getId() {
            return id;
        }
    
        public void setId(Integer id) {
            this.id = id;
        }
    
        public String getServices() {
            return services;
        }
    
        public void setServices(String services) {
            this.services = services;
        }
    }
    
  • Mapper接口

    public interface ServiceGroupMapper {
        
        public void updateServices(List<ServiceGroup> update);
    }
    
    
  • Mapper.xml文件中的update语句

    <update id="updateServices" parameterType="com.zongze.domain.ServiceGroup">
            update service_group
            <trim prefix="set" suffixOverrides=",">
                <trim prefix=" services = case" suffix="end,">
                    <foreach collection="list" index="index" item="item">
                    when id = #{item.id, jdbcType=INTEGER} then #{item.services, jdbcType=LONGVARCHAR}
                    </foreach>
                </trim>
            </trim>
            where id in
            <foreach close=")" collection="list" item="item" open="(" separator=",">
                #{item.id, jdbcType=INTEGER}
            </foreach>
        </update>
    
  • 控制台输出SQL语句

     update service_group set services = CASE WHEN id=? THEN ? WHEN id=? THEN ? END WHERE id in (?,?)
    
  • Mysql语句

    update service_group set services = CASE WHEN id=1 THEN '{"服务1,服务2"}' WHEN id=2 THEN '{"服务2,服务3"}' END WHERE id in (1,2);
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值