在设计数据库表的时候,为保证数据记录的唯一,防止并发情况下,数据库插入多条数据,我们通常会设计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 的相关字段,注意后面字段的写法。