数据库插入/更新前校验唯一索引

业务场景:对于某个数据库,在新增或者修改数据之前,需要校验某个有唯一索引的字段内容是否已经存在,如果存在,查询出已存在的数据绑定的信息并返回(抛错或者return Result.error)

1、如果需要查询信息并且返回:

单独写一个select,查询已经有的信息并且返回:

Mapper.xml

    <select id="getInfosByRfid" resultType="返回DO实体类">
        SELECT rfid, info1 , info2....
        from xxxinfo 
        and rfid in
        <foreach item="rfid" index="index" collection="rfids" open="(" separator="," close=")">
            #{rfid}
        </foreach>
    </select>

如果查询到了结果,返回你想要的数据集合,如果查询不到,结果列表是空

2、如果不需要信息,只需要是否重复(效率优化):

<select id="checkReapeatByRfid" parameterType="string" resultType="integer">
    select exists (select * from xxxinfo where rfid in
    <foreach item="item" index="index" collection="rfidList" open="(" separator="," close=")">
        #{item}
    </foreach>
    ) as exist_result
</select>

如果查询到了结果,返回1,反之,返回0;

返回的字段越少,效率越高,内存占用越小。

唯一索引可能存在的坑:使用逻辑删除时,唯一索引依然存在,虽然记录已经逻辑删除,但是需要校验的字段内容仍然被占用,导致无法更新或新增。

这个目前还没写, 等下一篇文的时候再搞吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值