MYSQL 之 ON DUPLICATE KEY UPDATE

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

这时可以使用 ON DUPLICATE KEY UPDATE

    <insert id="insert" parameterType="com.uc.dal.domain.HouseAccountDO">
        INSERT INTO
          iotx_uc_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
        iotx_uc_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 的相关字段,注意后面字段的写法。

猜你喜欢

转载自my.oschina.net/freedemon/blog/1813358