关于@Transactional事务不回滚

最近在公司有一个需求:大致上是要我去做一个产品的登入的审核接口。
因为有大量的对数据库修改、提交以及查询的操作,我使用了@Transaction 让这个接口交给spring事务来托管。
其中出现了修改抛出异常了(已设定了,如果输入不符合我的规范会throw new myException),但是数据库数据仍被修改了。
大概在网上找了好几种原因以及解决办法,不过首先先介绍我当时用的解决办法。

我所使用的解决办法

首次认为我觉得我自己配置有问题,但是又不想深究下去了,采用了很直接的方法---手动回滚
我把这些抛出的异常改为一个发送到前端的错误信息,通过判断是否有误flag的对错来最终执行回滚。
大概代码:

if (flag){
    TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
    return.........
}

这种解决办法简单而且无脑,不过自己深究下去之后,也明白了其中的原因,下面先介绍@Transactional事务不回滚的原因

@Transactional事务不回滚的原因

  1. @Transactional 注解必须作用在public的权限管理上,其余的权限管理关键字并不会使事物生效
  2. 检查数据库是否支持事务(例如MySql4.0 支持事务,Engine:InnoDB)
  3. 检查代码块是否抛出异常,且事务的rollback的异常是抛出异常或者是抛出异常的父类(默认是RuntimeException)

引用一下第三点原因,若我在@Transactional加上(rollbackFor = { myException.class }),应该也可以解决问题,而且改动是最少的

  1. 检查事务覆盖的代码块中的所有Connection是否都被这个事务覆盖(debug检查所有connection的autoCommit属性是不是被事务改成了false)
  2. @Transactional 的事务开启 ,或者是基于接口的 或者是基于类的代理被创建。在同一个类中一个方法调用另一个方法有事务的方法,事务是不会起作用的。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、事务简单介绍 事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功。 1.1 事...
    tuacy阅读 117,010评论 11 110
  • 11. 事务管理 11.1 Spring Framework事务管理介绍 广泛的事务支持是Spring Frame...
    此鱼不得水阅读 640评论 0 0
  • 1 事务 1.1 事务管理方式 spring支持编程式事务管理和声明式事务管理两种方式。 编程式事务管理使用Tra...
    鑫奕航阅读 2,861评论 0 1
  • http://liuxing.info/2017/06/30/Spring%20AMQP%E4%B8%AD%E6%...
    sherlock_6981阅读 16,105评论 2 11
  • 1.数据库事务基础知识 1.1.何为数据库事务 数据库事务的4个特性 原子性:组成一个事务的多个数据库操作是一个不...
    小螺钉12138阅读 1,634评论 1 18