解决spring data jpa 批量保存更新的问题
spring data jpa 批量保存更新问题
使用jpa批量保存时,看日志发现是一条一条打印的,然后去看了下源码,果然是循环调用的单个保存(巨坑啊)

经查询jpa是可以实现批量保存更新的,具体设置如下:
spring.jpa.properties.hibernate.jdbc.batch_size=500 spring.jpa.properties.hibernate.jdbc.batch_versioned_data=true spring.jpa.properties.hibernate.order_inserts=true spring.jpa.properties.hibernate.order_updates =true
其中:batch_size根据自己的数据库情况来设置
配置好后,感觉终于可以批量保存了,立马试了一把,结果,一首凉凉。。。(并没什么用)
继续查资料,终于发现了还有一个坑,那就是jpa中主键策略会影响批量功能!!
如果主键策略使用了IDENTITY 也就是@GeneratedValue(strategy = GenerationType.IDENTITY),那么批量功能不支持的,
如果要开启批量,那么就要使用sequence策略,也就是@GeneratedValue(strategy = GenerationType.SEQUENCE),
然后立马去开启,结果发现再次入坑,原来mysql数据库是无法使用sequence策略的,已泪奔。。。。。
批量功能只能自己去单独找寻方法实现了。
jpa在批量添加的时候,存储慢如何解决问题
spring.datasource.url = jdbc:mysql://xxxxxxxx:xxxx/xxxxx?useSSL=false&useUnicode=true&characterEncoding=utf-8&rewriteBatchedStatements=true&autoReconnect=true

入口下加
@EnableTransactionManagement @SpringBootApplication @EnableTransactionManagement
service实现类下加
@Service @Transactional 
sql语句这样写:根据自己的字段多少来写格式不能变下面是一个demo
String sql = “INSERT INTO xxxx(id,name,age) VALUES (:id,:name,:age)”; List uparChnMulMinList = (List) map.get(“uparChnMulMinList”); SqlParameterSource[] batch = SqlParameterSourceUtils.createBatch(uparChnMulMinList.toArray()); namedParameterJdbcTemplate.batchUpdate(sql, batch);
自定义的list:List
SqlParameterSourceUtils导入这个直接用,调用这个方法createBatch();
开启数据空批量配置:
rewriteBatchedStatements=true
开启事务:
@EnableTransactionManagement ,@Transactional
可以一试。以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java面试岗常见问题之ArrayList和LinkedList的区别
ArrayList和LinkedList作为我们Java中最常使用的集合类,很多人在被问到他们的区别时,憋了半天仅仅冒出一句:一个是数组一个是链表。这样回答简直让面试官吐血。为了让兄弟们打好基础,我们通过实际的使用测试,好好说一下ArrayList和LinkedList的区别这道经典的面试题2022-01-01
MyBatis中 @Mapper 和 @MapperScan 的区别与使用解析
本文介绍了SpringBoot中MyBatis的两个常用注解:@Mapper和@MapperScan,@Mapper用于标记单个Mapper接口,而@MapperScan用于批量扫描指定包下的所有Mapper接口,两者都有各自适用的场景,选择合适的注解可以提高开发效率并使代码更加简洁,感兴趣的朋友一起看看吧2025-01-01
详解在SpringBoot中使用MongoDb做单元测试的代码
这篇文章主要介绍了详解在SpringBoot中使用MongoDb做单元测试的代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-11-11


最新评论