栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

  1. 阅读交易看起来确实很奇怪,在这种情况下,人们通常不会标记交易方法。但是JDBC仍然会创建事务,只是
    autocommit=true
    如果未显式设置其他选项,它将可以正常工作。
  2. 但是,不能保证您的方法不会写入数据库。如果将method标记为
    @Transactional(readonly=true)
    ,Spring会将JDBC事务设置为只读模式,因此您将决定在该事务范围内是否 实际上 可以写入DB。如果您的体系结构繁琐,并且某些团队成员可能选择将修改查询放在不希望出现的地方,则此标志会将您指向有问题的地方。
  3. DB也可以优化只读事务,但这当然是特定于DB的。例如,MySQL从5.6.4版本开始仅在InnoDB中添加了对此的支持。
  4. 如果您不是直接使用JDBC,而是使用ORM,则可能会出现问题。例如,Hibernate社区说在事务外工作可能会导致不可预知的行为。这是因为Hibernate将打开事务,但不会自行关闭它,因此连接将被返回到连接池,而未提交事务。那会发生什么呢?JDBC保持沉默,因此这是特定于实现的(MySQL回滚事务,Oracle afair提交)。这也可以在连接池级别上配置(例如C3P0为您提供了这样的选项,默认情况下为回滚)。
  5. 关于Hibernate的另一件事,在只读事务的情况下,Spring将FlushMode设置为MANUAL,这会导致其他优化,例如不需要脏检查。
  6. 您可能需要覆盖或显式设置事务隔离级别。这也会影响读取事务,因为您要读取或不希望读取未提交的更改,暴露于幻像读取等。

综上所述-您可以双向进行,但您需要了解后果。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/375712.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号