Duplicate entry 'xxx' for key 'xxx'

插入数据的时候 报错,Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry 'xxx-xxx-xxx-xxx-xxx' for key 'AA'

1、这段信息给出的是索引重复,就去找数据是否相同,但是并不相同。

2、又由于'xxx-xxx-xxx-xxx-xxx'部分只显示60个字符,怀疑是数据被截取,变换参数值尝试,还是报错。

3、再次对批量的数据逐条debug,最后定位到出错的那条数据,发现是组合索引中的一个参数,有大小写两条数据,在插入后一条时报错。

4、对数据库中的该字段,根据业务需要,改成支持大小写的。

5、mysql的唯一索引或组合索引中某个字段,设置区分大小写。具体操作: 字段设定里面有一个【二进制(Binary)】的选项,需要区分大小写的字段勾上就可以了。

 

踩坑点:

1、堆栈打印的错误信息 索引重复只打印部分,不打印全部,这个导致排查耗时。

2、mysql的索引添加时,默认不区分大小写。

转载于:https://www.cnblogs.com/boomoom/p/9670302.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值