Hibernate主键生成策略strategy = "increment"报错违反唯一性约束

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate主键生成策略strategy = "increment"报错违反唯一性约束相关的知识,希望对你有一定的参考价值。

背景
2018年7月份,系统爆出一条bug。就是支持Excel导入的功能,导入第二次同模板不同数据时,报错,违反唯一性约束。就死活用不了了,重启Tomcat才能恢复使用。但只能到一个文件

分析
需要重启Tomcat,应该是缓存的原因

原因
分析完所有代码,临时数据使用clear换成new,不行;
内存使用监控,导入完模板,就恢复正常,不是;
最后,看着异常找原因,发现Hibernate的主键策略是strategy = "increment"

尝试
会不会是hibernate主键策略选择不正确,因为选择的主键策略就是不能出现删除。

收集
Hibernate所有的主键策略

https://www.cnblogs.com/hoobey/p/5508992.html

解决
选用程序自动生成主键策略,调整后strategy = "assigned"

技术分享图片

以上是关于Hibernate主键生成策略strategy = "increment"报错违反唯一性约束的主要内容,如果未能解决你的问题,请参考以下文章

hibernate注解note

ssh注解中主键生成策略无效

JPA主键生成策略

SpringDataJPA中出现的保存出现的Caused by: org.hibernate.PersistentObjectException: detached entity passed to

Hibernate主键生成策略

Hibernate框架Hibernate主键生成策略