Spring: try-catch 是否还会回滚
问题出现:
try-catch 语句 依旧会抛出如下错误
org.springframework.transaction.TransactionSystemException: Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnlyat org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.java:526)at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:761)at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:730)at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:518)at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:292)at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96)
问题解决:
try-catch 为什么还会事务回滚
在编程中,使用 try-catch 语句块确实可以帮助你捕获和处理异常,但这并不直接影响数据库事务的提交或回滚。事务的提交或回滚通常是由事务管理器根据事务的边界和事务属性(如隔离级别、传播行为等)来控制的,而不是直接由 try-catch 语句块控制的。
然而,有几个原因可能导致在使用 try-catch 时事务仍然回滚:
-
未捕获的异常:如果事务中的代码抛出了未被
try-catch捕获的异常,那么这个异常将传播到事务的边界,导致事务管理器触发回滚操作。 -
运行时异常:在 Spring 等框架中,默认情况下,运行时异常(
RuntimeException及其子类)会导致事务回滚。即使你在try-catch中捕获了这些异常,如果没有显式地调用事务的提交方法(在大多数场景下,这是不必要的,因为框架会为你管理事务),事务管理器仍然会根据异常的类型和配置来决定是否回滚事务。 -
事务传播行为:如果你在一个已经存在的事务中开始了一个新的事务(例如,使用了 Spring 的
@Transactional注解,并且事务的传播行为是REQUIRED或其他允许嵌套事务的行为),那么内部事务的异常可能会影响到外部事务的状态,导致外部事务也回滚。这取决于具体的事务管理器和配置。 -
事务回滚的显式请求:在某些情况下,你的代码可能显式地请求了事务回滚,即使异常被捕获了。例如,在 Spring 中,你可以通过编程方式调用
TransactionStatus.setRollbackOnly()来标记事务需要回滚。 -
框架或容器的行为:使用的框架或容器(如 Spring、EJB 等)可能有自己的事务管理策略,这些策略可能会根据捕获的异常类型、事务的属性或其他因素来决定是否回滚事务。
-
数据库约束:即使你的代码中没有异常,数据库级别的约束(如主键冲突、外键约束等)也可能导致 SQL 语句执行失败,从而触发事务回滚。
因此,当你看到即使使用了 try-catch 事务仍然回滚时,你应该检查以下几点:
- 是否有未捕获的异常。
- 是否捕获了运行时异常但期望事务继续。
- 事务的传播行为和嵌套事务的处理方式。
- 是否有显式地请求事务回滚的代码。
- 数据库约束是否可能导致事务失败。
此外,了解你使用的框架或容器的事务管理策略和配置也是非常重要的。
捕获了运行时异常但期望事务继续
在大多数现代Java框架(如Spring)中,运行时异常(RuntimeException 及其子类)默认会导致事务回滚。这是因为运行时异常通常表示程序中的错误,这些错误可能破坏了数据的完整性或一致性,因此框架选择自动回滚事务以避免潜在的问题。
然而,如果你捕获了运行时异常但仍然希望事务继续(即不触发回滚),你需要采取一些额外的步骤来确保这一点。但是,请注意,这种做法通常是不推荐的,因为它可能隐藏了潜在的问题并导致数据不一致。
在Spring框架中,你可以通过以下几种方式来处理这个问题:
-
使用
@Transactional(noRollbackFor = ...)或@Transactional(noRollbackForClassName = ...)你可以在服务层的方法上使用
@Transactional注解,并通过noRollbackFor或noRollbackForClassName属性来指定哪些异常不应该导致事务回滚。但是,请注意这些属性只接受编译时异常(即那些继承自Exception但不继承自RuntimeException的异常)。对于运行时异常,你需要使用@Transactional(rollbackFor = Exception.class, noRollbackFor = YourSpecificRuntimeException.class)这样的组合,但实际上由于Exception.class已经包括了所有的异常,所以只需要noRollbackFor就足够了。但更常见的做法是将rollbackFor留空,仅使用noRollbackFor。然而,由于
noRollbackFor不直接支持运行时异常,你需要显式地列出不希望回滚的运行时异常类型。
@Transactional(noRollbackFor = YourSpecificRuntimeException.class)
public void yourServiceMethod() { try { // 可能会抛出 YourSpecificRuntimeException 的代码 } catch (YourSpecificRuntimeException e) { // 处理异常,但希望事务继续 // 注意:这里不会阻止事务回滚,因为@Transactional的noRollbackFor属性需要精确匹配 }
}
-
但是,由于Spring的
@Transactional注解在方法边界上处理事务,并且不直接检查方法体内部的异常处理逻辑,因此上述noRollbackFor的使用实际上是在说:“如果这个方法抛出了YourSpecificRuntimeException,请不要回滚事务。” 它并不依赖于你是否在方法内部捕获了这个异常。
-
编程式事务管理
如果你需要更细粒度的控制,可以考虑使用编程式事务管理。这允许你在代码中显式地开始、提交或回滚事务。但是,这种方法更加复杂,并且通常不推荐用于服务层方法,因为它与声明式事务管理相比更加繁琐且容易出错。
-
重新考虑异常处理策略
最后,你可能需要重新考虑你的异常处理策略。通常,如果一个运行时异常表明数据可能已经处于不一致的状态,那么回滚事务是保护数据完整性的正确做法。如果你的业务逻辑允许在发生特定运行时异常时继续执行(尽管这很少见),你可能需要重新设计你的业务逻辑或异常处理逻辑,以确保数据的一致性和完整性不会受到影响。
总的来说,虽然你可以通过@Transactional注解的noRollbackFor属性来防止某些特定的运行时异常导致事务回滚,但通常建议仔细考虑是否真的需要这样做,并确保你的业务逻辑和数据完整性不会因此受到损害。
--end--
相关文章:
Spring: try-catch 是否还会回滚
问题出现: try-catch 语句 依旧会抛出如下错误 org.springframework.transaction.TransactionSystemException: Could not commit JPA transaction; nested exception is javax.persistence.RollbackException: Transaction marked as rollbackOnlyat org.springf…...
spdlog日志库--基础介绍
文章目录 1. 简介1.1. spdlog代码特点1.2. 说明1.3. spdlog架构 2. spdlog的安装2.1. 使用包管理器安装2.2. 使用源码安装2.3. 仅使用头文件 3. 相关概念3.0 常用的头文件3.1. level_enum3.2. sink3.3. logger3.4 格式输出3.5 对齐方式3.6 截断3.7 字符串格式化fmt 4. 特性4.1.…...
【网络】网络编程套接字(二)
网络编程套接字(二) 文章目录 1.单执行流的TCP网络程序1.1服务端创建套接字1.2服务端绑定1.3服务端监听1.4服务端获取链接1.5服务端处理请求1.6客户端创建套接字1.7客户端连接服务器1.8客户端发起请求 2.多进程版的TCP网络程序2.1单执行流的弊端2.2多进…...
1.1、centos stream 9安装Kubernetes v1.30集群 环境说明
最近正在学习kubernetes,买了一套《Kubernetes权威指南 从Docker到Kubernetes实践全接触(第六版)》这本书讲得很好,上下两册,书中k8s的版本是V1.29,目前官网最新版本是v1.30。强烈建议大家买一套看看。 Kubernetes官网地址&#x…...
Redis3
目录 什么是缓存穿透?怎么解决? 什么是缓存雪崩?怎么解决? 如何保证数据库和缓存的数据一致性? 如何保证Redis服务高可用? 哨兵的作用 Redis虚拟槽分区有什么优点? 为什么Redis集群最大槽…...
Oracle数据巡检 - 设计巡检模板
设计巡检模板 明确巡检数据库等信息 包括数据库种类、版本、架构、数量等,例如 Oracle DG和Oracle RAC数据库巡检项肯定会有差异,Oracle 11g和12c版本巡检内容也会有所不同。 明确巡检项 这一块需要结合自身的运维经验,列出详尽的巡检项&…...
优盘未格式化数据恢复实战指南
在数字时代,优盘(USB闪存驱动器)作为便携存储媒介,承载着无数重要的文件与数据。然而,当您插入优盘准备访问资料时,却遭遇了“驱动器未被格式化”的提示,这无疑是一场突如其来的数据危机。本文将…...
【python基础】python基础习题练习(一)
文章目录 一. python语言简介二. python基本语法与常用函数三. python基本数据类型一.选择题二.编程题四. python组合数据类型一.选择题二.简答题三.编程题一. python语言简介 查看python是否安装成功的命令是:python -vPython IDE有:pyCharm、Spyder、Jupter NotebookPython…...
GESP 4级样题 ---> 绝对素数
这题需要判断一个数和它的反转后的数是否都为素数。 可以转成 string 后 reverse 一下。 AC CODE: #include <bits/stdc.h> using namespace std; typedef long long LL; bool isPrime(int x){if(x<2) return false;for(int i2;i*i<x;i){if(x%i0) re…...
大语言模型系列 - Transformer
1. 简介 1.1. 概述 大语言模型Transformer是一种由谷歌公司提出的基于注意力机制的神经网络模型,它在自然语言处理(NLP)领域取得了显著成就,并逐渐被应用于其他领域如语音识别、计算机视觉和强化学习等。 1.2. 学习资源 以下是一些学习大语言模型Transformer的资源地址…...
Java面试之操作系统
1、冯诺依曼模型 运算器、控制器、存储器、输入设备、输出设备 32位和64位CPU最主要区别是一次性能计算多少字节数据,如果计算的数额不超过 32 位数字的情况下,32 位和 64 位 CPU 之间没什么区别的,只有当计算超过 32 位数字的情况下&#…...
springboot船舶维保管理系统--论文源码调试讲解
第二章 相关技术 本次开发船舶维保管理系统使用的是Vue进行程序开发,船舶维保管理系统的数据信息选择MySQL数据库进行存放。 2.1 VUE介绍 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue…...
【机器学习西瓜书学习笔记——神经网络】
机器学习西瓜书学习笔记【第五章】 第五章 神经网络5.1神经元模型5.2 感知机与多层网络学习感知机学习率成本/损失函数梯度下降 5.3 BP神经网络(误差逆传播)5.4 全局最小与局部极小5.5 其他常见神经网络RBF网络RBF 与 BP 最重要的区别 ART网络 第五章 神…...
安装 electron 报错解决
1. 报错 大概率由镜像问题导致 2. 解决 2.1 打开 npm 配置 npm config edit 2.2 添加配置 registryhttps://registry.npmmirror.comelectron_mirrorhttps://cdn.npmmirror.com/binaries/electron/electron_builder_binaries_mirrorhttps://npmmirror.com/mirrors/electron…...
【Material-UI】Icon Button 组件详解
文章目录 一、基础用法1. 禁用状态 二、大小(Sizes)1. 小尺寸(Small)2. 大尺寸(Large) 三、颜色(Colors)1. 主题颜色2. 自定义颜色 四、高级用法和最佳实践1. 无障碍性(A…...
51单片机-第七节-DS1302实时时钟
一、DS1302介绍: 实时时钟芯片,可对年,月,日,周,时,分,秒计时,是一种集成电路。 二、DS1302原理: 1.寄存器定义: Command:操作模式…...
Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序
Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序 这篇博文将介绍一个基于SSM框架和Vue开发的图书馆座位预约系统微信小程序,适合用于Java毕业设计。 功能介绍 用户 登录 注册 首页 图片轮播 关于我们 公告信息 图书馆信息 图书馆详情 预约选座 收藏 …...
【C++11】:lambda表达式function包装器
目录 前言一,可变参数模板1.1 简单认识1.2 STL容器中的empalce系列相关接口 二,lambda表达式2.1 lambda表达式语法2.2 探索lambda底层 三,包装器3.1 function包装器3.2 bind 四,类的新功能4.1 默认成员函数4.2 关键字default4.3 关…...
[io]进程间通信 -有名、无名管道 区别
有名管道和无名管道的区别 无名管道有名管道 使用场景 亲缘关系进程不相关的任意进程特点 1.固定读端fd[0]写端fd[1] 2.文件IO进行操作 3.不支持lseek()操作 4.数据存储在内核空间 1.文件系统中存在管道文件 2.文件IO操作 3.不支持lseek 4.先进先出 5.数…...
pywinauto:Windows桌面应用自动化测试(七)
前言 上一篇文章地址: pywinauto:Windows桌面应用自动化测试(六)-CSDN博客 下一篇文章地址: 暂无 一、实战常用方法 1、通过Desktop快速获取窗口 通过之前章节我们了解到控制应用的方法为Application࿰…...
Jetson Orin Nano 升级jetpack5.1.2刷机过程记录
一.刷机起因 orin nano 接了个IMX477的摄像头,用 命令行DISPLAY:0.0 nvgstcapture-1.0 显示的画面有撕裂,让卖家查问题,卖家测试没有撕裂,对比环境,orin nano出厂默认的是jetpack5.1.1,卖家用的jetpack5.1.2版本,为了解决差异,要升级jetpack版本,前后搞了2天半,记录一下. 另外…...
2026年,揭秘那些真正安全的原生态食材厂家你不可不知的秘密
随着人们生活水平的提升以及对健康的日益重视,选择真正安全的原生态食材已经成为许多人购买食物的标准。但市场的繁杂使得甄别真正安全的食材厂家变得愈加困难。今天,我将通过几个关键角度,为大家揭秘那些真正安全的原生态食材厂家的秘密&…...
Office RibbonX Editor:简单三步打造你的专属Office界面
Office RibbonX Editor:简单三步打造你的专属Office界面 【免费下载链接】office-ribbonx-editor An overhauled fork of the original Custom UI Editor for Microsoft Office, built with WPF 项目地址: https://gitcode.com/gh_mirrors/of/office-ribbonx-edit…...
如何用Python脚本榨干百度网盘带宽:pan-baidu-download终极指南
如何用Python脚本榨干百度网盘带宽:pan-baidu-download终极指南 【免费下载链接】pan-baidu-download 百度网盘下载脚本 项目地址: https://gitcode.com/gh_mirrors/pa/pan-baidu-download 在数字时代,百度网盘已成为我们存储和分享大型文件的默认…...
紧急预警:DeepSeek代码生成中未公开的3类逻辑漂移现象(附自动化检测脚本+修复模板)
更多请点击: https://intelliparadigm.com 第一章:紧急预警:DeepSeek代码生成中未公开的3类逻辑漂移现象(附自动化检测脚本修复模板) 近期在多轮生产级代码审计中发现,DeepSeek-R1(v2.5&#x…...
通用物联网开发板设计:基于ESP8266的硬件集成与开发实践
1. 项目概述:为什么我们需要一块“通用”的物联网开发板?在捣鼓了几年物联网项目之后,我发现自己桌面上堆满了各种开发板:ESP8266、ESP32、Arduino Uno、STM32 Nucleo……每个项目都要重新连线、配置电源、焊接传感器接口…...
Godot 2D随机地图三大静默故障:黑屏、穿墙、寻路失败的根源与修复
1. 为什么刚上手Godot做2D随机地图就总卡在“生成出来是黑的”“角色穿墙”“房间连不通”这三件事上?如果你是刚从Unity或GameMaker转来Godot,或者第一次用GDScript写程序逻辑的新手,大概率已经在2D随机地图生成这个环节反复摔过跟头——不是…...
低空旅游观光与低空通勤(eVTOL)运营管理与服务保障平台建设方案
本方案旨在为eVTOL载具构建集运营管理、空中交通管制、安全保障与乘客服务于一体的数字化平台。通过微服务架构、5G-A融合感知、空域网格化与零信任安全等核心技术,解决高密度飞行中的资源调度与安全冲突问题。目标实现毫秒级冲突解算与15分钟内快速周转,…...
DeepSeek代码审查能力白皮书(2024企业级实测报告)
更多请点击: https://kaifayun.com 第一章:DeepSeek代码审查能力白皮书(2024企业级实测报告)概述 本报告基于2024年Q1至Q3期间,面向金融、电信与云原生三大垂直行业的17家头部企业客户开展的深度实测,覆盖…...
摆脱论文困扰!2026年最值得拥有的专业AI智能降重工具
2026年论文降AI率工具已从“基础改写”升级为多维度智能优化系统,核心评价维度涵盖AI生成内容识别精度、语义逻辑一致性、学术格式合规性、查重适配能力及多语言处理水平。本次测评覆盖6款主流工具,测试场景包括中文与英文论文、全流程与专项功能、免费与…...
