java 数据库 事务 只读_为什么我在Hibernate中需要Transaction才能进行只读操作?

问题

为什么我在Hibernate中需要Transaction才能进行只读操作?

以下事务是否锁定了db?

从db获取的示例代码:

Transaction tx = HibernateUtil.getCurrentSession().beginTransaction(); // why begin transaction?

//readonly operation here

tx.commit() // why tx.commit? I don't want to write anything

我可以使用session.close()而不是tx.commit() ??

#1 热门回答(99 赞)

实际上,你可能有理由将事务标记为只读。

阅读交易看起来确实很奇怪,在这种情况下,人们通常不会为交易标记方法。但是JDBC无论如何都会创建事务,如果没有明确设置不同的选项,它只会在autocommit = true中工作。

但不能保证你的方法不会写入数据库。如果将方法标记为@Transactional(readonly = true),Spring会将JDBC事务设置为只读模式,因此你将决定是否可以在此事务的范围内写入DB。如果你的架构非常繁琐,并且某些团队成员可能不遵循合理的路径,那么此标志会指向你有问题的地方。

DB也可以优化只读事务,但这当然是特定于数据库的。例如。 MySQL仅在InnoDB中添加了对5.6.4版本的支持。

如果你没有直接使用JDBC,而是使用ORM,则可能会出现问题。例如,Hibernate社区表示在事务之外工作可能会导致不可预测的行为。这是因为Hibernate将打开事务,但它

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值