2021-06-11 08:34:26 作者:年少bu轻狂
使用jpa批量保存时,看日志发现是一条一条打印的,然后去看了下源码,果然是循环调用的单个保存(巨坑啊)
配置好后,感觉终于可以批量保存了,立马试了一把,结果,一首凉凉。。。(并没什么用)
继续查资料,终于发现了还有一个坑,那就是jpa中主键策略会影响批量功能!!
如果主键策略使用了IDENTITY 也就是@GeneratedValue(strategy = GenerationType.IDENTITY),那么批量功能不支持的,
如果要开启批量,那么就要使用sequence策略,也就是@GeneratedValue(strategy = GenerationType.SEQUENCE),
然后立马去开启,结果发现再次入坑,原来mysql数据库是无法使用sequence策略的,已泪奔。。。。。
批量功能只能自己去单独找寻方法实现了。
service实现类下加
sql语句这样写:根据自己的字段多少来写格式不能变下面是一个demo
自定义的list:List
SqlParameterSourceUtils导入这个直接用,调用这个方法createBatch();
开启数据空批量配置:
开启事务:
可以一试。以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
电脑版 - 返回首页
2006-2024 脚本之家 JB51.Net , All Rights Reserved. 苏ICP备14036222号