详解Spring中REQUIRED事务的回滚机制详解

2025-09-23 00:50

本文主要是介绍详解Spring中REQUIRED事务的回滚机制详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《详解Spring中REQUIRED事务的回滚机制详解》在Spring的事务管理中,REQUIRED是最常用也是默认的事务传播属性,本文就来详细的介绍一下Spring中REQUIRED事务的回滚机制,...

在 Spring 的事务管理中,REQUIRED 是最常用也是默认的事务传播属性。很多开发者在使用时会遇到一个常见的困惑:为什么内部方法抛出的异常即便被外层捕获了,事务还是会整体回滚? 本文将深入剖析 REQUIRED 下的事务回滚机制及其背后的原理。

1. REQUIRED 的定义

  • 默认传播属性
  • 如果当前存在事务:加入当前事务。
  • 如果没有事务:创建一个新事务。

这意味着调用链上的所有方法都运行在同一个物理事务里,彼此之间没有隔离。只要其中一个方法触发回滚条件,整个事务都会被撤销。

2. REQUIRED 下的回滚机制

2.1 异常触发回滚

Spring 默认回滚规则:

  • 运行时异常(RuntimeException)和错误(Error):触发回滚。
  • 受检异常(ChjavascripteckedException):不会触发回滚,除非在 @Transactional(rollbackFor = Exception.class) 中显式指定。

2.2 回滚状态传播

假设调用链如下:

@Transactional(propagation = Propagation.REQUIRED)
public void ouwww.chinasem.cnter() {
    try {
        inner();
    } catch (Exception e) {
        // 异常被捕获
    }
}

@Transactional(propagation = Propagation.REQUIRED)
public void inner() {
    throw new RuntimeException("内部错误");
}

执行过程:

  1. outer() 启动时创建事务。
  2. inner() 加入同一事务并抛出异常。
  3. Spring 的事务拦截器捕获异常 → 标记当前事务为 rollback-only
  4. 即便外层 outer() 捕获了异常,rollback-only 标记不会自动清除。
  5. 最终事务提交时,Spring 检查到 rollback-only → 调用 rollback() 而不是 commit()

因此,捕获异常并不能阻止事务回滚

3. 为什么捕获异常也会回滚?

原因在于 Spring 的事务是基于 事务状态标记 而不是你的 try-catch 来决定的:

  • 方法抛出异常 → TransactionInterceptor 判断是否需要回滚。
  • 如果符合规则 → status.setRollbackOnly()
  • 外层即便捕获异常,也只是业务层逻辑“消化”了异常,但事务状态已经不可提交。

最终由事务管理器在 commit() 阶段检查 rollback-only 标记,决定整体回滚。

4. 如何避免“误回滚”?

如果确实需要内部异常不影响外部事务,可以考虑以下方式:

4.1 修改回滚规则

@Transactional(noRollbackFor = RuntimeException.class)
public void inner() {
    throw new RuntimeException("不会触发回滚");
}

但这种方式风险极高,可能提交错误数据。

4.2 手动清理事务状态(不推荐)

catch (Exception e) {
    TransactionASPectSupport.currentTransactionStatus().setRollbackOnly(false);
}

此方式非常危险,通常不建议。

4.3 使用其他传播js属性(推荐)

  • REQUIRES_NEW:为内部方法开启新事务,失败只影响内部,不影响外部。
  • NESTED:使用保存点,内部失败可回滚到保存点,外部事务继续。

这两种方式才是更优雅的解决方案。

5. Spring 内部执行流程

核心逻辑在 TransactionAspectSupport.invokeWithinTransaction()

  1. 获取或创建事务。
  2. 执行目标方法。
  3. 捕获异常 → 判断是否需要回滚 → 设置 rollback-only。
  4. 方法结束 → 根据状态决定 commit() 还是 rollback()

6. 总结

  • REQUIRED 下,所有方法共享一个事务。
  • 任意方法异常触发 rollback-only → 整体回滚。
  • 捕获异常≠事务安全,Spring 根据事务状态决定提交还是回滚。
  • 如果需要更细粒度的控制,应使用 REQUIRES_NEWNESTED

一句话总结:在 Spring 的 REQUIRED 模式下,事务是一荣俱荣、一损俱损的整体,内部异常即便被捕获也会让整个事务回滚,真正想做到“局部回滚”需要换传播属性来实现。

到此这篇关于详解Spring中REQUIRED事务的回滚机制详解的文章就介绍到这了,更多相关Spring REQUIRED 事务回滚内容请搜索China编程(jswww.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于详解Spring中REQUIRED事务的回滚机制详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155976

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置