大学IT网 - 最懂大学生的IT学习网站! QQ资料交流群:367606806
当前位置:大学IT网 > Java技巧 > Spring事务的传播方式

Spring事务的传播方式

关键词:Spring事务传播方式  阅读(845) 赞(11)

[摘要]本文是对Spring事务的传播方式的讲解,对学习Java编程技术有所帮助,与大家分享。

Spring定义了一下几种事务传达方式:

PROPAGATION_REQUIRED 支持以后事务,假定以后没有事务,就新建一个事务。这是最稀有的选择。

PROPAGATION_SUPPORTS 支持以后事务,假定以后没有事务,就以非事务方式执行。

PROPAGATION_MANDATORY 支持以后事务,假定以后没有事务,就抛出异常。

PROPAGATION_REQUIRES_NEW 新建事务,假定以后存在事务,把以后事务挂起。

PROPAGATION_NOT_SUPPORTED 以非事务方式执行操作,假定以后存在事务,就把以后事务挂起。

PROPAGATION_NEVER 以非事务方式执行,假定以后存在事务,则抛出异常。

PROPAGATION_NESTED 假定以后事务存在,则以嵌套事务的方式执行。否则就依照它本人的事务方式执行。

required
supports
mandatory //命令的;强迫的
requires_new
not_supported
nerver
nested

1: PROPAGATION_REQUIRED

参与以后正要执行的事务不在另外一个事务里,那么就起一个新的事务

比方说,ServiceB.methodB的事务级别定义为PROPAGATION_REQUIRED, 那么由于执行ServiceA.methodA的时分, ServiceA.methodA曾经起了事务,这时调用ServiceB.methodB,ServiceB.methodB看到本人曾经运转在ServiceA.methodA 的事务外部,就不再起新的事务。而假定ServiceA.methodA运转的时分发现本人没有在事务中,他就会为本人分配一个事务。 这样,在ServiceA.methodA或许在ServiceB.methodB内的任何中央呈现异常,事务都会被回滚。即便ServiceB.methodB的事务曾经被提交,但是ServiceA.methodA在接上去fail要回滚,ServiceB.methodB也要回滚。

2: PROPAGATION_SUPPORTS

假定以后在事务中,即以事务的方式运转,假定以后不再一个事务中,那么就以非事务的方式运转。

3: PROPAGATION_MANDATORY

必需在一个事务中运转。也就是说,他只能被一个父事务调用。否则,他就要抛出异常。

4: PROPAGATION_REQUIRES_NEW

这个就比拟绕口了。 比方我们设计ServiceA.methodA的事务级别为PROPAGATION_REQUIRED,ServiceB.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

了解Nested的关键是savepoint。他与PROPAGATION_REQUIRES_NEW的区别是,PROPAGATION_REQUIRES_NEW另起一个事务,将会与他的父事务互相独立, 而Nested的事务和他的父事务是相依的,他的提交是要等和他的父事务一块提交的。也就是说,假定父事务最初回滚,他也要回滚的。

而Nested事务的益处是他有一个savepoint。也就是说ServiceB.methodB失败回滚,那么ServiceA.methodA也会回滚到savepoint点上,ServiceA.methodA可以选择另外一个分支,比方 ServiceC.methodC,持续执行,来尝试完本钱人的事务。 但是这个事务并没有在EJB规范中定义。



相关评论