文件名称 | 版本号 | 作者 | 版本 | |
---|---|---|---|---|
解决问题:当mp mybatis批量插入时,数字id重复 | v1.0.1 | 学生宫布 | 8416837 | SpringBoot 2.2.6 mp 3.3.2 |
报错全称
java.lang.RuntimeException: org.apache.ibatis.exceptions.PersistenceException:
insert (batch index #1) failed. Cause: java.sql.BatchUpdateException:
Duplicate entry '1282559846490578945' for key 'PRIMARY'"
代码
疑似产生的原因
- 很明显是批量插入时,主键相同了,因为这个主键大概是根据时间戳生成的,当批量执行时,时间戳相同导致生成的主键冲突!
- 调试代码发现主键确实重复了,——而
并不是
网上说的索引重复,这个索引重复的解决办法:insert时加入ignore关键字,但本文所述问题并不是如此;
弯路、坑
分析
因为使用的是mp自带的原生的service的批量更新功能,所以应当提前给entity的主键赋值
解决方案
- insert之前,给每个entity的主键赋值;
关于
若交流技术,请联系qq:8416837