首页 > Java > java教程 > 正文

如何在Hibernate中执行批量插入更新操作?

WBOY
发布: 2023-08-27 23:17:06
转载
2311人浏览过

如何在hibernate中执行批量插入更新操作?

在本文中,我们将看到如何在Hibernate中执行批量插入/更新。

每当我们执行一条sql语句时,我们都是通过对数据库进行网络调用来完成的。现在,如果我们必须向数据库表中插入 10 个条目,那么我们必须进行 10 次网络调用。相反,我们可以通过使用批处理来优化网络调用。批处理允许我们在单个网络调用中执行一组 SQL 语句。

为了理解和实施这一点,让我们定义我们的实体−

@Entity
public class Parent {
   @Id
   @GeneratedValue(strategy = GenerationType.AUTO)
   private long id;
   private String name;
   // Getters
   //Setters
}
登录后复制

为了在Hibernate中启用批处理,我们需要向我们的应用程序添加一个属性

properties文件:

spring.jpa.properties.hibernate.jdbc.batch_size=3
登录后复制

现在,我们需要执行EntityManager的persist函数将数据插入数据库

示例

@Autowired
private EntityManager entityManager;
@Test
Public void InsertInBatch(){
   for (int i = 0; i < 6; i++) {
      Parent parent = Parent[i];
      entityManager.persist(parent);
   }
}
登录后复制

输出

"batch":true, "querySize":1, "batchSize":3, "query":["insert into parent (name, id) values (?, ?)"], "params":[["P1","1"],["P2","2"],["P3","3"]]
"batch":true, "querySize":1, "batchSize":3, "query":["insert into parent (name, id) values (?, ?)"], "params":[["P4","4"],["P5","5"],["P6","6"]]
登录后复制

从控制台我们可以看到,插入父表的操作是在批量大小为3的情况下进行的。

行者AI
行者AI

行者AI绘图创作,唤醒新的灵感,创造更多可能

行者AI100
查看详情 行者AI

在持久化实体时,可能会发生OutOfMemoryException,因为Hibernate将实体存储在持久化上下文中。因此,出于优化目的,我们可以在每批之后使用实体管理器的flush()和clear()。

批量更新意味着在一次网络调用中更新大量数据。

对于批量更新,流程是相同的。我们需要在应用程序属性文件中添加以下两个语句,然后执行更新过程。

spring.jpa.properties.hibernate.order_updates=true
spring.jpa.properties.hibernate.batch_versioned_data=true
登录后复制

示例

更新数据的代码−

@Autowired
private EntityManager entityManager;
@Test
public void UpdateInBatch() {
   TypedQuery<Parent> query = entityManager.createQuery("SELECT p from Parent p", Parent.class);
   List<Parent> Parents = query.getResultList();
   int i=1;
   for (Parent parent : Parents) {
      String s="Parent"+Integer.toString(i);
      i++;
      parent.setName(s);
   }
}
登录后复制

Hibernate 现在会将这些语句绑定在一个批处理中并执行它们。

输出

"batch":true, "querySize":1, "batchSize":3, "query":["update parent set name=? where id=?"], "params":[["Parent1","1"],[" Parent2","2"],[" Parent3","3"]]
"batch":true, "querySize":1, "batchSize":3, "query":["update parent set name=? where id=?"], "params":[["Parent4","4"],["Parent5","5"],["Parent6","6"]]
登录后复制

从控制台可以看到,父表中的数据更新是在批量大小为3的情况下进行的。

以上就是如何在Hibernate中执行批量插入更新操作?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:tutorialspoint网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号