返回顶部
首页 > 资讯 > 后端开发 > Python >解决spring data jpa 批量保存更新的问题
  • 671
分享到

解决spring data jpa 批量保存更新的问题

2024-04-02 19:04:59 671人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

spring data jpa 批量保存更新问题 使用jpa批量保存时,看日志发现是一条一条打印的,然后去看了下源码,果然是循环调用的单个保存(巨坑啊) 经查询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
![在这里插入图片描述](https://img-blog.csdnimg.cn/20191220111053531.png引用
@Autowired
private NamedParameterJdbcTemplate namedParameterJdbcTempla

在这里插入图片描述

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

可以一试。以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 解决spring data jpa 批量保存更新的问题

本文链接: https://lsjlt.com/news/128032.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作