为啥阿里巴巴规定要在 @Transactional 指定 rollbackFor?

简介: 为啥阿里巴巴规定要在 @Transactional 指定 rollbackFor?

阿里巴巴Java开发手册规范提示:方法【edit】需要在Transactional注解指定rollbackFor或者在方法中显示的rollback。

1.异常的分类

先来看看异常的分类

image.pngimage.png可查的异常(checked exceptions):


Exception下除了RuntimeException外的异常


不可查的异常(unchecked exceptions):


RuntimeException及其子类和错误(Error)


如果不对运行时异常进行处理,那么出现运行时异常之后,要么是线程中止,要么是主程序终止。


如果不想终止,则必须捕获所有的运行时异常,决不让这个处理线程退出。队列里面出现异常数据了,正常的处理应该是把异常数据舍弃,然后记录日志。不应该由于异常数据而影响下面对正常数据的处理。


非运行时异常是RuntimeException以外的异常,类型上都属于Exception类及其子类。如IOException、SQLException等以及用户自定义的Exception异常。对于这种异常,JAVA编译器强制要求我们必需对出现的这些异常进行catch并处理,否则程序就不能编译通过。


所以,面对这种异常不管我们是否愿意,只能自己去写一大堆catch块去处理可能的异常。


2.@Transactional 的写法

开始主题@Transactional如果只这样写,Spring框架的事务基础架构代码将默认地只在抛出运行时和unchecked exceptions时才标识事务回滚。


也就是说,当抛出个RuntimeException 或其子类例的实例时。(Errors 也一样 - 默认地 - 标识事务回滚。)从事务方法中抛出的Checked exceptions将 不 被标识进行事务回滚。


1 让checked例外也回滚:在整个方法前加上


@Transactional(rollbackFor=Exception.class)


2 让unchecked例外不回滚:


@Transactional(notRollbackFor=RunTimeException.class)


3 不需要事务管理的(只查询的)方法:


@Transactional(propagation=Propagation.NOT_SUPPORTED)


注意:如果异常被try{}catch{}了,事务就不回滚了,如果想让事务回滚必须再往外抛try{}catch{throw Exception}。事务失效的 8 大原因这篇看一下。


注意:


Spring团队的建议是你在具体的类(或类的方法)上使用 @Transactional 注解,而不要使用在类所要实现的任何接口上。你当然可以在接口上使用 @Transactional 注解,但是这将只能当你设置了基于接口的代理时它才生效。


因为注解是不能继承的,这就意味着如果你正在使用基于类的代理时,那么事务的设置将不能被基于类的代理所识别,而且对象也将不会被事务代理所包装(将被确认为严重的)。


因此,请接受Spring团队的建议并且在具体的类上使用 @Transactional 注解。


另外,@Transactional 注解标识的方法,处理过程尽量的简单。尤其是带锁的事务方法,能不放在事务里面的最好不要放在事务里面。可以将常规的数据库查询操作放在事务前面进行,而事务内进行增、删、改、加锁查询等操作。


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本文链接:https://blog.csdn.net/Mint6/article/details/78363761


推荐去我的博客阅读更多:


1.Java JVM、集合、多线程、新特性系列教程


2.Spring MVC、Spring Boot、Spring Cloud 系列教程


3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程


4.Java、后端、架构、阿里巴巴等大厂最新面试题


觉得不错,别忘了点赞+转发哦!


相关文章
|
3月前
|
Java 编译器 数据库
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
39 3
|
3月前
|
Java 编译器 数据库
在事务注解@Transactional中指定rollbackFor
在事务注解@Transactional中指定rollbackFor
34 0
|
Java 数据库连接 API
十二.Spring源码剖析-Transactional 事务执行流程
上一篇《[Transactional源码解析](https://blog.csdn.net/u014494148/article/details/118398677)》我们介绍了Spring对Transactional的解析,也就是事务的初始化工作,这一篇我们接着来分析事务的执行流程。
|
3月前
|
监控 安全 Java
Spring注解之恋:@Async和@Transactional的双重奏
Spring注解之恋:@Async和@Transactional的双重奏
489 0
|
消息中间件 JavaScript 小程序
如何将 @Transactional 事务注解运用到炉火纯青?
如何将 @Transactional 事务注解运用到炉火纯青?
|
SQL 消息中间件 JavaScript
我在项目里用@Transactional注解控制事务,结果完全不生效,纳尼?
我在项目里用@Transactional注解控制事务,结果完全不生效,纳尼?
|
数据库
Transactional注解不生效案例
Transactional注解不生效案例
131 0
Transactional注解不生效案例
|
缓存 Java 数据库连接
Spring源码剖析之Transactional事务
我们知道使用@Transactional,要满足以下条件 1、配置数据源 DataSource 2、配置事务管理器 PlatformTransactionManager 3、配置类上标识 @EnableTransactionManagement
170 0
|
存储 SQL Java
聊一聊使用事务时(@Transactional)可能出现的问题
聊一聊使用事务时(@Transactional)可能出现的问题
300 0
聊一聊使用事务时(@Transactional)可能出现的问题
|
Java Spring
@Transactional(rollbackFor)
@Transactional注解有两个 • 一个是spring提供的@org.springframework.transaction.annotation.Transactional • 另一个是jdk提供@javax.transaction.Transactional。
186 0