spring 事物传播的一些易错点

在spring中采用tx方式配置

<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="synch*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" />
<tx:method name="update*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" />
<tx:method name="save*" propagation="NOT_SUPPORT" read-only="false"
rollback-for="java.lang.Exception" />
<tx:method name="insert*" propagation="REQUIRED" read-only="false"
rollback-for="java.lang.Exception" />
</tx:attributes>
</tx:advice>

<aop:config expose-proxy="true" proxy-target-class="true">
<!-- 只对业务逻辑层实施事务 -->
<aop:pointcut id="txPointcut"
expression="execution(* com.sgm.xxx.*.service.*+.*(..))" />
<aop:advisor id="txAdvisor" advice-ref="txAdvice"
pointcut-ref="txPointcut" />
</aop:config>

在serviceimpl中例如updateDad && saveSon 方法进行相互套用,则只取第一个

public int updateDad(){

//正常执行sql

updateDadMapper.update();

updateDadMapper.update();

this.saveSon(); 

 

}

public int saveSon (){

//正常执行sql

updateDadMapper.save();

//报错sql

updateDadMapper.saveError();

}

 

1.因为在updateDad 方法中有事物REQUIRED,尽管在saveSon 方法中配置了not_support(不采取事物),,因为在方法中进行了嵌套,所以导致saveson 方法也拥有了REQUIRED整个方法是拥有事物的。例如如上例子所有执行的sql都会进行回滚。

反之

如果在saveSon中调用了updateDad,因为saveSon以非事物方式执行,所以整个方法中都不执行事物。

 

2.try catch 方法会拦截事物的处理,即trycatch的代码内容都不会执行事物。

 

转载于:https://www.cnblogs.com/a969695791/p/8886891.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值