• <sup id="mk476"></sup>
    <dl id="mk476"></dl>
  • <progress id="mk476"><tr id="mk476"></tr></progress>
    <div id="mk476"><tr id="mk476"></tr></div>
    <sup id="mk476"><ins id="mk476"></ins></sup>
  • <progress id="mk476"></progress>
    <div id="mk476"></div>
    <div id="mk476"><tr id="mk476"></tr></div>
  • <div id="mk476"></div>
    <dl id="mk476"><s id="mk476"></s></dl><dl id="mk476"></dl><div id="mk476"></div>
  • <div id="mk476"></div>
    <dl id="mk476"><ins id="mk476"></ins></dl>

    导航

    公告

    ??本文主要介绍下Spring事务中的传播行为。

    事务传播行为介绍

    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.methodB,ServiceB.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_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

    ??如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。

    Spring中事务的配置

    配置文件的方式

    <tx:advice id="txAdvice" transaction-manager="txManager"> 
          <tx:attributes>  
          <!--设置所有匹配的方法,然后设置传播级别和事务隔离-->
               <tx:method name="save*" propagation="REQUIRED" /> 
               <tx:method name="add*" propagation="REQUIRED" /> 
               <tx:method name="create*" propagation="REQUIRED" /> 
               <tx:method name="insert*" propagation="REQUIRED" /> 
               <tx:method name="update*" propagation="REQUIRED" /> 
               <tx:method name="merge*" propagation="REQUIRED" /> 
               <tx:method name="del*" propagation="REQUIRED" /> 
               <tx:method name="remove*" propagation="REQUIRED" /> 
               <tx:method name="put*" propagation="REQUIRED" /> 
               <tx:method name="get*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="count*" propagation="SUPPORTS" read-only="true" /> 
              <tx:method name="find*" propagation="SUPPORTS" read-only="true" /> 
              <tx:method name="list*" propagation="SUPPORTS" read-only="true" /> 
              <tx:method name="*" propagation="SUPPORTS" read-only="true" /> 
         </tx:attributes> 
    </tx:advice> 

    注解的方式

    <!--开启注解的方式--> 
    <tx:annotation-driven transaction-manager="transactioManager" />

    @Transactional(propagation=Propagation.REQUIRED)
    如果有事务, 那么加入事务, 没有的话新建一个(默认情况下)
    @Transactional(propagation=Propagation.NOT_SUPPORTED)
    容器不为这个方法开启事务
    @Transactional(propagation=Propagation.REQUIRES_NEW)
    不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
    @Transactional(propagation=Propagation.MANDATORY)
    必须在一个已有的事务中执行,否则抛出异常
    @Transactional(propagation=Propagation.NEVER)
    必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反)
    @Transactional(propagation=Propagation.SUPPORTS)
    如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.

    posted on 2019-02-24 08:49 ゞ .邓澎波 阅读(...) 评论(...) 编辑 收藏

    统计

    江苏11选5软件 龙江体彩6十开奖结果 天津快乐10分软件 金沙娱乐城网上赌博场 山西快乐十分基础走势 012期二肖中特 幸运飞艇计划数据下载 重庆时时彩三星彩经网 浙江快乐彩兑奖时间 北京快乐8大小单双概率 至尊宝平特规律论坛 pk10广西快乐10分彩票 赢三张炸金花 天津十一选五基本走势 一波中特最准单双 香港六合彩免费公开