mysql索引使用注意事项-1

Integrity constraint violation: 1062 Duplicate entry,

今天犯了一个十分致命且低级的错误,

这个问题出现的原因是因为你的字段设置了唯一索引而你打算插入或者更新的值不是唯一的。

为什么我设置了唯一索引值确产生了不唯一性,是因为默认值,null也好,0也,empty string,这些都会影响唯一性的判断。

我的错误产生(与君共勉):

     表中有一个字段是hash,这个字段是唯一的,hash值在我的业务里出现就是唯一,因为这个hash可以当作类似订单的查询条件,我就给他加了一个唯一索引,为了它能更快速的查询,反而铸成大错。

        1.生成订单(hash这时候没有获取到,默认是空字符串),返回订单id

        2.调取接口获取hash,根据订单id更新这个hash

        3.问题来了,当我第一个hash为空的数据,没有更新hash值,第二个为空的数据便执行了插入操作,这时候,hash有2个空,就不唯一了,数据库就会报错,

        4.即便代码中有校验hash唯一性的代码,这种情况还是不能避免发生,

现在看来这个问题真的很低级,可是设计到金额的逻辑却十分的致命,下次在设定唯一索引时候一定要考虑全面,不但要考虑这个值是否会产生重复,还要考虑到会不会有默认值的情况下冲突。哎,大晚上的出现这个问题真的很闹心,搞的一帮同事被我连累。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值