关于Spring的@Transactional注解失效以及事务无法回滚问题

@Transactional失效问题

  最近写的项目中需要一个service中的部分事务执行完就被commit,但是部分service需要失败回滚。因此写在一个大的service中并且加上@Transactional显然是无法满足需求的。
 因此这是需要把原先的一个service服务拆分,如原先的serviceA被拆分成serviceA和ServiceB,并且在ServiceB上打@Transactional注解,而serviceA未打注解。
 整体执行流程是由controller调用serviceA,再经serviceA调用serviceB。但是在执行过程发现serviceB中的事务语句在执行后就会被立马提交,事务控制未生效。
 翻阅资料有的说因为context:component-scan重复加载导致失效,但是sprintg配置中扫描service的包无重复。于是抱着试试的心态在serviceA上继续添加@Transactional注解,返现这是serviceB的事务生效。也就是说带事务注解的serviceA被其他service调用时,如果想要生效,最外层的也得加上@Transactional注解。

@Transactional,失败无法回滚

 紧接着上个问题说,serviceB中的事务生效后,在执行遇到异常时,捕获并且抛出自定的异常InvalidException extends Exception。发现执行的sql事务无法回滚。无奈只能在注解上加上rollbackFor = InvalidException.class。但是为了弄明白原因,断点调试到spring底层代码,发现这么一句代码

 return (ex instanceof RuntimeException || ex instanceof Error);

 就是说要想事务回滚你的异常要么派生自RuntimeException或者Error,于是把InvalidException改成集成RuntimeExcepiton,并且把注解中的rollbackFor去除,发现也是可以正常回滚。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
@Transactional注解失效的情况有以下几种: 1. 方法没有被Spring代理 - 由于Spring事务管理是基于AOP实现的,所以只有被Spring代理的方法才会被@Transactional注解所识别。如果方法没有被代理,那么@Transactional注解将无效。 2. 异常被catch住 - 如果在带有@Transactional注解的方法中,捕获了异常并且没有再次抛出,那么事务将不会回滚事务只有在未被捕获的异常发生时才会回滚。 3. 事务方法内部调用 - 如果在同一个类中的方法内部调用带有@Transactional注解的方法,那么事务注解将无效。这是因为Spring使用基于代理的事务管理,而同一个类中的方法调用并不会通过代理。 4. 异常不属于rollbackFor指定的类型 - @Transactional注解的rollbackFor参数可以指定回滚的异常类型。如果抛出的异常不属于指定的类型,事务将不会回滚。 5. 事务方法是私有的、final的或静态的 - @Transactional注解只能应用于public方法。私有的、final的或静态的方法无法事务管理。 6. 异常被try-catch重新抛出并修改了异常类型 - 如果在带有@Transactional注解的方法中,捕获了异常并在重新抛出时修改了异常类型,那么事务将不会回滚事务回滚是基于异常类型的匹配,修改异常类型会导致匹配失败[3]。 7. 方法内部调用self method - 如果在同一个类中的方法内部调用了自身的方法,事务注解将无效。这是因为同一个类中的方法调用不会通过代理,所以事务注解不会生效。 以上是一些常见的@Transactional注解失效的情况,需要注意这些情况以确保事务能够正确地生效。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [@Transactional注解失效的情况](https://blog.csdn.net/qq_40834643/article/details/128535431)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值