网站建设亿玛酷信赖,apache 安装 wordpress,正规的网站制作电话,网页传奇霸主高手攻略事务传播行为介绍
Spring中的7个事务传播行为: 事务行为 说明 PROPAGATION_REQUIRED 支持当前事务#xff0c;假设当前没有事务。就新建一个事务 PROPAGATION_SUPPORTS 支持当前事务#xff0c;假设当前没有事务#xff0c;就以非事务方式运行 PROPAGATION_MANDATORY…事务传播行为介绍
Spring中的7个事务传播行为: 事务行为 说明 PROPAGATION_REQUIRED 支持当前事务假设当前没有事务。就新建一个事务 PROPAGATION_SUPPORTS 支持当前事务假设当前没有事务就以非事务方式运行 PROPAGATION_MANDATORY 支持当前事务假设当前没有事务就抛出异常 PROPAGATION_REQUIRES_NEW 新建事务假设当前存在事务。把当前事务挂起 PROPAGATION_NOT_SUPPORTED 以非事务方式运行操作。假设当前存在事务就把当前事务挂起 PROPAGATION_NEVER 以非事务方式运行假设当前存在事务则抛出异常 PROPAGATION_NESTED 如果当前存在事务则在嵌套事务内执行。如果当前没有事务则执行与PROPAGATION_REQUIRED类似的操作。
举例说明
案例代码
ServiceA
ServiceA { void methodA() { ServiceB.methodB();}
}
复制
ServiceB
ServiceB { void methodB() { }
}
复制
1.PROPAGATION_REQUIRED 假如当前正要运行的事务不在另外一个事务里那么就起一个新的事务 比方说ServiceB.methodB的事务级别定义PROPAGATION_REQUIRED, 那么因为执行ServiceA.methodA的时候ServiceA.methodA已经起了事务。这时调用ServiceB.methodBServiceB.methodB看到自己已经执行在ServiceA.methodA的事务内部。就不再起新的事务。而假如ServiceA.methodA执行的时候发现自己没有在事务中他就会为自己分配一个事务。这样在ServiceA.methodA或者在ServiceB.methodB内的不论什么地方出现异常。事务都会被回滚。即使ServiceB.methodB的事务已经被提交可是ServiceA.methodA在接下来fail要回滚ServiceB.methodB也要回滚 2.PROPAGATION_SUPPORTS 假设当前在事务中。即以事务的形式执行。假设当前不在一个事务中那么就以非事务的形式执行
3PROPAGATION_MANDATORY 必须在一个事务中执行。也就是说他仅仅能被一个父事务调用。否则他就要抛出异常
4.PROPAGATION_REQUIRES_NEW 这个就比较绕口了。 比方我们设计ServiceA.methodA的事务级别为PROPAGATION_REQUIREDServiceB.methodB的事务级别为PROPAGATION_REQUIRES_NEW。那么当运行到ServiceB.methodB的时候ServiceA.methodA所在的事务就会挂起。ServiceB.methodB会起一个新的事务。等待ServiceB.methodB的事务完毕以后他才继续运行。 他与PROPAGATION_REQUIRED 的事务差别在于事务的回滚程度了。由于ServiceB.methodB是新起一个事务那么就是存在两个不同的事务。假设ServiceB.methodB已经提交那么ServiceA.methodA失败回滚。ServiceB.methodB是不会回滚的。假设ServiceB.methodB失败回滚假设他抛出的异常被ServiceA.methodA捕获ServiceA.methodA事务仍然可能提交。 5.PROPAGATION_NOT_SUPPORTED 当前不支持事务。比方ServiceA.methodA的事务级别是PROPAGATION_REQUIRED 。而ServiceB.methodB的事务级别是PROPAGATION_NOT_SUPPORTED 那么当执行到ServiceB.methodB时。ServiceA.methodA的事务挂起。而他以非事务的状态执行完再继续ServiceA.methodA的事务。
6.PROPAGATION_NEVER 不能在事务中执行。 如果ServiceA.methodA的事务级别是PROPAGATION_REQUIRED。 而ServiceB.methodB的事务级别是PROPAGATION_NEVER 那么ServiceB.methodB就要抛出异常了。
7.PROPAGATION_NESTED 如果当前存在事务则在嵌套事务内执行。如果当前没有事务则执行与PROPAGATION_REQUIRED类似的操作。
Spring中事务的配置
配置文件的方式
tx:advice idtxAdvice transaction-managertxManager
tx:attributes
!--设置所有匹配的方法然后设置传播级别和事务隔离--
tx:method namesave* propagationREQUIRED /
tx:method nameadd* propagationREQUIRED /
tx:method namecreate* propagationREQUIRED /
tx:method nameinsert* propagationREQUIRED /
tx:method nameupdate* propagationREQUIRED /
tx:method namemerge* propagationREQUIRED /
tx:method namedel* propagationREQUIRED /
tx:method nameremove* propagationREQUIRED /
tx:method nameput* propagationREQUIRED /
tx:method nameget* propagationSUPPORTS read-onlytrue /
tx:method namecount* propagationSUPPORTS read-onlytrue /
tx:method namefind* propagationSUPPORTS read-onlytrue /
tx:method namelist* propagationSUPPORTS read-onlytrue /
tx:method name* propagationSUPPORTS read-onlytrue /
/tx:attributes
/tx:advice
复制
注解的方式
!--开启注解的方式--
tx:annotation-driven transaction-managertransactioManager /
复制
Transactional(propagationPropagation.REQUIRED) 如果有事务, 那么加入事务, 没有的话新建一个(默认情况下) Transactional(propagationPropagation.NOT_SUPPORTED) 容器不为这个方法开启事务 Transactional(propagationPropagation.REQUIRES_NEW) 不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务 Transactional(propagationPropagation.MANDATORY) 必须在一个已有的事务中执行,否则抛出异常 Transactional(propagationPropagation.NEVER) 必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反) Transactional(propagationPropagation.SUPPORTS) 如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.