只读事务与不使用事务的区别

1、查询结果不同

  • 不使事务:默认情况下每次查询,查询到的都是其他事物已提交的数据。
  • 只读事务:从只读事务开始直到事务结束,整个过程其他事务提交的数据,该事务过程中都忽略。即查询过程中,不会查询到该事物开启之后任何改变的数据。

2、适用场景不同

  • 1、单条sql语句的查询,不必启用只读事务
  • 2、多条sql语句的查询并且要求多条SQL查询出的数据必须保证整体一致性,需要启用只读事务

原因:在前面SQL查询执行结束,接下来执行后续SQL查询之前,数据发生了改变,那么本次整体查询结果将会出现数据不一致的情况。所以,要求多条SQL查询出的数据必须保证一致性的查询语句也应该启用事务支持

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring中,只事务事务是两种不同的事务类型。只事务用于查询操作,不允许对数据库进行修改操作,而事务则可以进行查询和修改操作。 如果需要在只事务中添加写操作,我们可以通过以下步骤进行修改: 1. 确定是否真正需要在只事务中进行写操作。由于只事务的设计初衷是为了提高查询性能和并发度,将写操作加入其中可能会降低性能。 2. 在Spring的事务管理配置文件(如XML配置文件或注解配置类)中,将只事务的isolation属性设置为默认级别或其他适当的级别,以允许写操作。例如,将isolation属性设置为READ_COMMITTED或其他适合的级别。 3. 在需要添加写操作的方法上,添加@Transactional注解或将@Transactional注解的只属性设为false,这将将方法标记为事务。 4. 在方法中进行必要的修改操作,并确保在对数据库进行写操作之前,正确地处理事务的提交和回滚。 需要注意的是,在只事务中添加写操作可能会引发一些问题。如果修改操作发生异常,只事务默认情况下将回滚事务。因此,在添加写操作时,必须确保在出现异常时正确处理事务的回滚和异常处理。 总之,如果需要在Spring的只事务中添加写操作,可以通过调整事务的隔离级别和在方法上添加@Transactional注解来实现。但是需要注意在这个过程中,适当处理事务的提交和回滚来确保数据的一致性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值