事务的传播机制
1、事务传播级别是REQUIRED,当checkout()被调用时(假定被另一类中commit()调用),如果checkout()中的代码抛出异常,即便被捕获,commit()中的其他代码都会roll back
2、是REQUIRES_NEW,如果checkout()中的代码抛出异常,并且被捕获,commit()中的其他代码不会roll back;如果commit()中的其他代码抛出异常,而且没有捕获,不会导致checkout()回滚
3、是NESTED,如果checkout()中的代码抛出异常,并且被捕获,commit()中的其他代码不会roll back;如果commit()中的其他代码抛出异常,而且没有捕获,会导致checkout()回滚
PROPAGATION_REQUIRES_NEW 启动一个新的, 不依赖于环境的 "内部" 事务. 这个事务将被完全 commited 或 rolled back 而不依赖于外部事务, 它拥有自己的隔离范围, 自己的锁, 等等. 当内部事务开始执行时, 外部事务将被挂起, 内务事务结束时, 外部事务将继续执行.
另一方面, PROPAGATION_NESTED 开始一个 "嵌套的" 事务, 它是已经存在事务的一个真正的子事务. 嵌套事务开始执行时, 它将取得一个 savepoint. 如果这个嵌套事务失败, 我们将回滚到此 savepoint. 潜套事务是外部事务的一部分, 只有外部事务结束后它才会被提交.
由此可见, PROPAGATION_REQUIRES_NEW 和 PROPAGATION_NESTED 的最大区别在于, PROPAGATION_REQUIRES_NEW 完全是一个新的事务, 而 PROPAGATION_NESTED 则是外部事务的子事务, 如果外部事务 commit, 嵌套事务也会被 commit, 这个规则同样适用于 roll back. 
传播级别:required nested required_new 。
required是完全归一个事务所有。如果子事务有异常需要回滚,即时外面的事务捕获了,回报rool back异常,告知需要回滚了。
nested 是当前新的事务嵌套在老事务之中。如果新的事务有异常,老事务不会回滚。如果老事务有异常嵌套的事务会进行回滚。
required-new 是完全开启一个新的事务。互不影响的。
关于rollbackFor的默认值
roalbackFor:默认时runtimeException和Error 。如果要时回滚Exception及子类,需要配置roalBackfor
@Transactional(propagation = Propagation.REQUIRED,rollbackFor = FileNotFoundException.class) 这样runTImeexception和fileNotFoundException都会回滚
如果某一个runTimeException不需要回滚,则在弄rollbackFor中配置。
本文来自博客园,作者:Jerry&Ming,转载请注明原文链接:https://www.cnblogs.com/jerry-ming/articles/16512650.html

浙公网安备 33010602011771号