解决springdatajpa批量保存更新的问题spring data jpa 批量保存更新问题
使⽤jpa批量保存时,看⽇志发现是⼀条⼀条打印的,然后去看了下源码,果然是循环调⽤的单个保存(巨坑啊)
经查询jpa是可以实现批量保存更新的,具体设置如下:
spring.jpa.properties.hibernate.jdbc.batch_size=500
spring.jpa.properties.hibernate.jdbc.batch_versioned_data=true
spring.jpa.der_inserts=true
spring.jpa.der_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
![在这⾥插⼊图⽚描述](img-blog.csdnimg/20191220111053531.png引⽤
@Autowired
private NamedParameterJdbcTemplate namedParameterJdbcTempla
sql语句这样写:根据⾃⼰的字段多少来写格式不能变下⾯是⼀个demo
String sql = “INSERT INTO xxxx(id,name,age) VALUES (:id,:name,:age)”;
List uparChnMulMinList = (List) (“uparChnMulMinList”);
SqlParameterSource[] batch = Array());
hibernate要学多久
namedParameterJdbcTemplate.batchUpdate(sql, batch);
⾃定义的list:List
SqlParameterSourceUtils导⼊这个直接⽤,调⽤这个⽅法createBatch();
开启数据空批量配置:
rewriteBatchedStatements=true
开启事务:
@EnableTransactionManagement ,@Transactional
可以⼀试。以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论