背景
2018年7月份,系统爆出一条bug。就是支持Excel导入的功能,导入第二次同模板不同数据时,报错,违反唯一性约束。就死活用不了了,重启Tomcat才能恢复使用。但只能到一个文件
分析
需要重启Tomcat,应该是缓存的原因
原因
分析完所有代码,临时数据使用clear换成new,不行;
内存使用监控,导入完模板,就恢复正常,不是;
最后,看着异常找原因,发现Hibernate的主键策略是strategy = "increment"
尝试
会不会是hibernate主键策略选择不正确,因为选择的主键策略就是不能出现删除。
收集
Hibernate所有的主键策略
https://www.cnblogs.com/hoobey/p/5508992.html
解决
选用程序自动生成主键策略,调整后strategy = "assigned"
原创文章,作者:3628473679,如若转载,请注明出处:https://blog.ytso.com/194721.html