MYSQL 之 ON DUPLICATE KEY UPDATE

在设计数据库表的时候,为保证数据记录的唯一,防止并发情况下,数据库插入多条数据,我们通常会设计uk。但有了uk后,会存在这样一个问题。一条记录不能被删除多次或插入多次,但实际业务中经常会有这样的应用场景的。比如一个用户绑定一个设备,我下次解绑后,还需要可以再次绑定。

这时可以使用 ON DUPLICATE KEY UPDATE

    <insert id="insert" parameterType="com.uc.dal.domain.HouseAccountDO">
        INSERT INTO
          house_account
          (<include refid="columns"/>)
        VALUES
          (now(), now(), #{houseId}, #{identityId}, #{role},#{houseAddress},#{deleted})
        ON DUPLICATE KEY UPDATE
        gmt_modified= now(),
        deleted=  #{deleted},
        role = #{role},
        houseAddress = #{houseAddress}
    </insert>
	
	<insert id="batchInsert" parameterType="com.uc.dal.domain.HouseAccountDO">
        INSERT INTO
        house_account
        (<include refid="columns"/>)
        VALUES
        <foreach collection="houseAccountDOList" separator="," index="index" item="item">
            (now(), now(), #{item.houseId}, #{item.identityId}, #{item.role},#{item.houseAddress}, #{item.deleted})
        </foreach>
        ON DUPLICATE KEY UPDATE
        gmt_modified= now(),
        deleted=VALUES(deleted),
        role = VALUES(role),
        house_address = VALUES(house_address)
    </insert>

上面的 sql 就可以完美的解决 uk 冲突的问题,其中 houseId ,identityId 是uk.

注意 ON DUPLICATE KEY UPDATE 后面不要写 uk 的相关字段,注意后面字段的写法。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值