解决问题:当mp mybatis批量插入时,数字id重复_v1.0.1

文件名称 版本号 作者 qq 版本
解决问题:当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的主键赋值

解决方案

  1. insert之前,给每个entity的主键赋值;

关于

若交流技术,请联系qq:8416837

你可能感兴趣的:(技术栈-关系数据库,Java持久层,mybatis)