Spring中事务的隔离级别和传播行为

一、 Spring中事务的隔离级别

  事务的隔离级别是指若干个并发的事务之间的隔离程度。
  在spring中,事务的隔离级别有五种设置方式(isolation属性的设置方式):

隔离级别说明
DEFAULT使用数据库本身使用的隔离级别:ORACLE(读已提交) MySQL(可重复读)
READ_UNCOMITTED读未提交(脏读),最低的隔离级别。
READ_COMITTED读已提交。Oracle默认隔离级别,有不可重复读和幻读的风险。
REPEATABLE_READ可重复读,MySQL默认隔离级别,有幻读的风险
SERLALIZABLE串行化,最高的隔离级别。不管多少事务,依次运行完一个事务的所有子事务之后,才可以执行另外一个事务里面的所有子事务。解决了脏读、不可重复读和幻读的问题。但是消耗大,性能不高。

二、Spring中事务的传播行为

  事务的传播行为用于指定在多个事务方法间调用时,事务是如何在这些方法间传播的。

在Spring中,事务有7中传播行为:

传播行为说明
propagation_requierd如果当前没有事务,就新建一个事务,如果已存在一个事务,则加入到这个事务中,这是最常见的选择 。即:如果methodA()方法中没有事务,methodB()方法中有事务,则methodB()中开启一个事务;如果methodA()方法有事务,则methodB()加入methodA()的事务中,不需要再开启一个事务。
propagation_supports支持当前事务,如果没有当前事务,就以非事务方法执行。即:如果methodA()方法中有事务,methodB()方法中有事务;如果methodA()方法没有事务,methodB()方法中有事务,那么methodB()异常不回滚。
propagation_mandatory使用当前事务时,如果没有当前事务,就抛出异常。即:如果methodA()方法中有事务,methodB()有事务;如果methodB()方法中没有事务,methodB()方法中有事务,methodB()异常回滚。
propagation_required_new新建事务,如果当前存在事务,把当前事务挂起
propagation_not_supported以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
propagation_never以非事务方式执行操作,如果当前事务存在则抛出异常。
propagation_nested如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与propagation_required类似的操作

注意:requires_new和nested的区别:

  • requires_new完全是一个新事务,nested是一个外部事务的子事务,是外部事务的一部分。
  • 对于nested,如果嵌套事务发生异常回滚,则只回滚嵌套事务部分;而外部事务的提交和回滚均会提交/回滚嵌套事务。
  • requires是两个事务互不干扰,如果内部事务发生异常且异常抛到了外部调用方法,那么两个事务都回滚,如果内部事务提交成功,外部事务提交失败,外部事务不影响内部事务,或者外部事务提交成功,但内部事务失败的异常被外部事务catch住,则不影响外部事务。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值