Hibernate 的 batch_size 与事务

batch_size 即同时提交数据的数量,原本与事务并没有什么关系,但如果涉及到同一张表数据的同一种操作,可能就会发生微妙的关系了。

场景如下:
场景一:使用 spring 控制事务,将方法事务配置为 not_supported,向同一张表中插入两条数据,保证第一条数据正常插入,而第二条数据受约束(如唯一约束)插入失败。

预测结果:第一条数据成功,第二条失败。
实际结果:两条数据均失败。
原因:hibernate 将两条插入放到了同一个 batch 中,提交同时失败了。

场景二:同样使用 spring 控制事务,将方法事务配置为 not_supported,向第一张表中插入一条合法数据,成功,向第二张表插入数据,受约束(如唯一约束)插入失败。

预测结果:第一条数据成功,第二条失败。
实际结果:第一条数据成功,第二条失败。
原因:hibernate 分别插入数据并提交,在无事务的情况下,第一条成功,第二条失败。

那么如何让场景一得到预测结果呢,一个简单的解决方法,将 hibernate.jdbc.batch_size 设置为 1,即可。

所以,即使控制了事务,也未必能够得到期望的结果,还需要考虑某些特殊的场景带来的影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
开启 Hibernate 5 的批处理需要两个配置:hibernate.jdbc.batch_sizehibernate.order_inserts。hibernate.jdbc.batch_size 表示批处理大小,hibernate.order_inserts 表示是否按照实体类的顺序插入数据。其操作步骤如下: 1. 在 Hibernate 配置文件中添加 hibernate.jdbc.batch_sizehibernate.order_inserts 配置; 2. 创建 Session 对象; 3. 开启事务; 4. 循环将多个对象添加到 Session 中; 5. 提交事务; 6. 关闭 Session。 下面是一个示例代码,假设要将多个用户信息批量插入到数据库中: ```java Session session = null; Transaction tx = null; try { // 添加 hibernate.jdbc.batch_sizehibernate.order_inserts 配置 Properties prop = new Properties(); prop.setProperty("hibernate.jdbc.batch_size", "50"); prop.setProperty("hibernate.order_inserts", "true"); sessionFactory = new Configuration().configure().addProperties(prop).buildSessionFactory(); // 创建 Session 对象 session = sessionFactory.openSession(); // 开启事务 tx = session.beginTransaction(); // 循环将多个对象添加到 Session 中 for (User user : users) { session.save(user); } // 提交事务 tx.commit(); } catch (Exception e) { // 回滚事务 if (tx != null) { tx.rollback(); } e.printStackTrace(); } finally { // 关闭 Session if (session != null) { session.close(); } } ``` 其中,users 是一个 User 对象的集合,表示多个用户信息。在添加完所有对象后,直接提交事务即可,Hibernate 会自动开启批处理。需要注意的是,批处理只在插入操作时起作用,更新和删除操作不会使用批处理。同时,批处理也可能会导致主键冲突等问题,需要根据实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值