news 2026/4/15 18:26:31

Spring Boot之@Transactional注解实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Spring Boot之@Transactional注解实践

在Spring Boot大行其道的时代,开发者可以通过@Transactional注解来方便的操作事务

隔离级别

@Transactional注解的isolation属性,可用来设置隔离级别。默认值为Isolation.DEFAULT。该属性可选值有:

  • Isolation.DEFAULT:数据源默认隔离级别
  • Isolation.READ_UNCOMMITTED:未提交读
  • Isolation.READ_COMMITTED:已提交读
  • Isolation.REPEATABLE_READ:可重复读
  • Isolation.SERIALIZABLE:串行化

回滚条件

@Transactional注解默认只会对RuntimeException、Error及其子类进行回滚。如果期望对检查异常进行回滚,可通过rollbackFor、rollbackForClassName属性添加新的回滚条件

// 方式1: 支持对所有异常类型进行回滚 @Transactional(rollbackFor = Exception.class) // 方式2:支持对所有异常类型进行回滚 @Transactional(rollbackForClassName = {"Exception"})

类似地,还可以排除某些异常,使之不发生回滚

// 方式1: 抛出ArithmeticException异常不进行回滚 @Transactional(noRollbackForClassName = {"ArithmeticException"} ) // 方式2: 抛出ArithmeticException异常不进行回滚 @Transactional(noRollbackFor = {ArithmeticException.class} )

上述四种回滚条件的属性对指定异常的子类也是生效的

只读事务

@Transactional注解的readOnly属性默认为false,如需只读事务可将其配置为true。在只读事务中不允许执行读之外操作,否则事务将会回滚

事务传播行为

@Transactional注解的propagation属性可用来设置事务传播行为,默认值为Propagation.REQUIRED。其用来表示当一个事务传播行为修饰的方法(即methodB)被另一个方法(即methodA)调用时,事务如何进行传播

public class ServiceA { public void methodA() { ... serviceB.methodB(); ... } } ... public class ServiceB { // 通过propagation属性指定methodB方法的事务传播行为 @Transactional(propagation = ...) public void methodB() { ... } }

Propagation.REQUIRED

支持当前事务;如果当前没有事务,则新建一个事务。如下图所示。这也是日常开发中最常使用的配置。在Case 1的场景下,无论methodA方法还是methodB方法出现异常,均会进行回滚,因为它们是在同一个事务中

Propagation.REQUIRES_NEW

新建事务;如果当前存在事务,则把当前事务挂起。如下图所示。以Case 1为例进行分析,由于methodA、methodB方法使用的是两个不同的事务,故当methodB方法提交后,即使methodA方法失败回滚了,也不会导致methodB方法出现回滚。当methodB方法失败回滚后,如果methodA未捕获methodB所抛出的异常,导致methodA继续抛出该异常则methodA方法也会被回滚;如果methodA方法捕获methodB所抛出的异常,则methodA所在的事务还是有可能提交成功的

Propagation.SUPPORTS

支持当前事务;否则将非事务方式执行。如下图所示

Propagation.MANDATORY

支持当前事务;否则将抛出IllegalTransactionStateException异常,此时不仅methodB方法无法得到执行,也会打断methodA方法的执行流程,除非在methodA方法中捕获处理该异常。如下图所示

Propagation.NOT_SUPPORTED

不支持当前事务,而是始终以非事务的方式执行。如下图所示

Propagation.NEVER

以非事务方式执行;如果当前存在事务,则抛出IllegalTransactionStateException异常,此时不仅methodB方法无法得到执行,还会打断methodA方法的执行流程,甚至导致methodA方法发生回滚

Propagation.NESTED

如果当前存在事务,则对于该传播行为修饰的方法会依然使用当前事务,这样一旦methodA方法进行回滚,则methodB方法也会进行回滚。但由于该传播行为是通过数据库事务的保存点进行实现的,那么一旦methodB方法抛出异常发生回滚。如果methodA方法捕获了methodB方法所抛出的异常,则methodA就不会因此而回滚;而methodA方法如果继续向上抛出异常则其也会被回滚;如果当前没有事务,则新建一个事务。如下图所示

Note

  1. 事务注解只会对public方法生效

当@Transactional事务注解添加在类上,表示其将作用于该类中的所有public方法

  1. 通过类内部调用事务方法,事务无法生效

例如下面代码所示,在A类内部通过一个普通方法methodA调用事务方法methodB,那么methodB的事务会生效么?

public class A { public void methodA() { ... methodB(); ... } @Transactional public void methodB() { ... } }

答案是,原因很简单。这里我们将Spring AOP后的动态代理类ProxyA用伪代码的形式给出,如下所示。可以看到,虽然动态代理类ProxyA中的methodB方法被加入了事务切面。但事实上调用ProxyA的methodA方法后,会直接进入目标类A中,即执行a.methodA()方法,然后直接调用A类中的methodB方法。换言之,methodB方法没有通过代理类ProxyA进行调用,自然其事务注解不会生效

public class ProxyA { private A a = new A(); public void methodA() { // 执行目标方法 a.methodA(); } public void methodB() { // 前置增强 ... // 执行目标方法 a.methodB(); // 后置增强 ... } }

即使在A类的methodA上也添加@Transactional事务注解,methodB方法由于没走代理类ProxyA,故methodB方法依然还是使用methodA方法的事务。即使将methodB方法的传播行为设置为Propagation.REQUIRES_NEW,也不会重新开启一个新的事务。因为methodB方法连@Transactional注解都无法生效,设置传播行为更是无任何意义

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 13:38:01

聊聊五种 Redis 部署模式

这篇文章,分享自己职业生涯经历的五种 Redis 部署模式,希望对大家有所启发。1 单实例这是 Redis 最简单、最基础的部署方式,即:整个 Redis 服务运行在单个服务器和单个进程中。笔者第一次在生产环境使用 Redis ,是在艺…

作者头像 李华
网站建设 2026/4/16 7:12:57

不止于Web:Python在CTF Pwn与逆向中的高阶利用技巧与实战分析

CTF网络安全大赛中的Python应用 CTF(Capture The Flag)网络安全大赛是一个在网络安全社区中广泛流行的竞赛形式。它通过各种挑战来检验参赛者的网络安全技能,包括逆向工程、漏洞利用、密码学、Web安全等。Python作为一种高效而强大的编程语言…

作者头像 李华
网站建设 2026/4/16 12:22:38

当 Agent 进入系统阶段,AI 产品开始真正分化

👋前言过去一年,AI 产品讨论里有两个词被反复提及:模型,和 Agent。但在越来越多真实项目中,一个更现实的问题正在浮现:当 Agent 不再是单点能力,而开始参与业务流程、并发任务和协同决策时&…

作者头像 李华
网站建设 2026/4/16 2:57:29

5 款 AI 写论文哪个好?实测宏智树 AI:毕业论文写作的全能型学术利器

毕业季的论文赛道上,“5 款 AI 写论文哪个好” 的灵魂拷问,总能在各大高校互助群里刷屏。不少同学踩坑无数:有的工具生成内容充斥 “文献幻觉”,有的查重结果与学校系统脱节,有的 AI 痕迹明显被检测预警。作为深耕论文…

作者头像 李华
网站建设 2026/4/16 15:32:12

什么是UI自动化测试?什么项目适合做UI自动化测试?

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快本文主要分享做简单的UI自动化测试简介、为何要做UI自动化测试、什么情况下适合做UI自动化测试以及其他的心得体会,希望能给各位同行带来思想上的碰撞。…

作者头像 李华
网站建设 2026/4/16 16:27:26

大模型微调常见问题解决方案汇总

一、环境配置类问题 环境配置是微调的第一步,也是最基础的环节,框架、硬件、依赖之间的兼容性问题,会直接导致后续工作无法开展,这类问题的排查优先级最高。 问题1:依赖版本冲突,安装后导入包时报错 这是最…

作者头像 李华