zoukankan      html  css  js  c++  java
  • 关于Spring事务回滚的问题

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

    [html] view plain copy
     
     print?
    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:如果没有在程序中手动捕获异常

    [java] view plain copy
     
     print?
    1. @Transactional(rollbackFor = { Exception.class })  
    2. public void test() throws Exception {  
    3.      doDbStuff1();  
    4.      doDbStuff2();//假如这个操作数据库的方法会抛出异常,现在方法doDbStuff1()对数据库的操作   会回滚。  
    5. }  


    情况2:如果在程序中自己捕获了异常

    [java] view plain copy
     
     print?
    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. }  


    现在如果我们需要手动捕获异常,并且也希望抛异常的时候能回滚肿么办呢?
    下面这样写就好了,手动回滚事务:

    [java] view plain copy
     
     print?
      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.      }  
      10. }  
  • 相关阅读:
    网页内容自动换行
    问题:Sql Server登录不进去的问题
    Truncate的用法
    SQL当前日期获取技巧
    .NET导出Excel遇到的80070005错误的解决
    养眼方式
    在页面里显示出PPT的效果
    问题(待解决):运行NCover产生的问题
    用CSS控制输入框输入的字母自动转入都是大写字母
    问题:Default引起的问题
  • 原文地址:https://www.cnblogs.com/zhuawang/p/5954819.html
Copyright © 2011-2022 走看看