关于Spring事务回滚的问题

原文地址

在Spring的配置文件中,如果数据源的defaultAutoCommit设置为True了,那么方法中如果自己捕获了异常,事务是不会回滚的,如果没有自己捕获异常则事务会回滚,如下例
比如配置文件里有这么条记录:

  1. <bean id="dataSource" class="xxx">  
  2.    <property name="xxx" value="xxx"/>  
  3.    <property name="xxx" value="xxx"/>  
  4.                      ....  
  5.      <property name="defaultAutoCommit" value="true" />  
  6. </bean>  

那么现在有两个情况
情况1:如果没有在程序中手动捕获异常
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() throws Exception {  
  3.      doDbStuff1();  
  4.      doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作   会回滚。  
  5. }  

情况2:如果在程序中自己捕获了异常
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() {  
  3.      try {  
  4.         doDbStuff1();  
  5.         doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作  不会回滚。  
  6.      } catch (Exception e) {  
  7.            e.printStackTrace();     
  8.      }  
  9. }  

现在如果我们需要手动捕获异常,并且也希望抛异常的时候能回滚肿么办呢?
下面这样写就好了,手动回滚事务:
  1. @Transactional(rollbackFor = { Exception.class })  
  2. public void test() {  
  3.      try {  
  4.         doDbStuff1();  
  5.         doDbStuff2();  
  6.      } catch (Exception e) {  
  7.           e.printStackTrace();     
  8.           TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();//就是这一句了,加上之后,如果doDbStuff2()抛了异常,                                                                                       //doDbStuff1()是会回滚的  
  9.      }  

以下是引用论坛的帖子对问题(对spring,mybatis进行整合时发现事务不能进行回滚处理)的分析


配置文件的问题吧?
1.root-context.xml
<!-- 不扫描带有@Controller注解的类。因为这些类已经随容器启动时,在servlet-context中扫描过一遍了 -->
<context:component-scan base-package="com.kimho">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
2、servlet-context.xml:
<!-- 扫描业务组件,让spring不扫描带有@Service注解的类(留在root-context.xml中扫描@Service注解的类),防止事务失效 -->
<context:component-scan base-package="com.kimho">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>



我前段时间和你遇到的问题一模一样,最后解决,问题原因如下:
1:如果按照你的步骤设置为ID为null的话,那么就需要捕获mybatis抛出的异常,然后在catch语句中抛出一个Exception,这个时候Spring容器的事务管理就会起作用,会回滚事务。
2:如果用mysql数据库,数据库表你如果是自动建表,那么就需要把建表的Engine设置为InnoDB格式,自动建表的格式为:MyISAM,这中格式的是不支持事务管理的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值