当前位置: 首页 > news >正文

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 时事务仍然回滚:

  1. 未捕获的异常:如果事务中的代码抛出了未被 try-catch 捕获的异常,那么这个异常将传播到事务的边界,导致事务管理器触发回滚操作。

  2. 运行时异常:在 Spring 等框架中,默认情况下,运行时异常(RuntimeException 及其子类)会导致事务回滚。即使你在 try-catch 中捕获了这些异常,如果没有显式地调用事务的提交方法(在大多数场景下,这是不必要的,因为框架会为你管理事务),事务管理器仍然会根据异常的类型和配置来决定是否回滚事务。

  3. 事务传播行为:如果你在一个已经存在的事务中开始了一个新的事务(例如,使用了 Spring 的 @Transactional 注解,并且事务的传播行为是 REQUIRED 或其他允许嵌套事务的行为),那么内部事务的异常可能会影响到外部事务的状态,导致外部事务也回滚。这取决于具体的事务管理器和配置。

  4. 事务回滚的显式请求:在某些情况下,你的代码可能显式地请求了事务回滚,即使异常被捕获了。例如,在 Spring 中,你可以通过编程方式调用 TransactionStatus.setRollbackOnly() 来标记事务需要回滚。

  5. 框架或容器的行为:使用的框架或容器(如 Spring、EJB 等)可能有自己的事务管理策略,这些策略可能会根据捕获的异常类型、事务的属性或其他因素来决定是否回滚事务。

  6. 数据库约束:即使你的代码中没有异常,数据库级别的约束(如主键冲突、外键约束等)也可能导致 SQL 语句执行失败,从而触发事务回滚。

因此,当你看到即使使用了 try-catch 事务仍然回滚时,你应该检查以下几点:

  • 是否有未捕获的异常。
  • 是否捕获了运行时异常但期望事务继续。
  • 事务的传播行为和嵌套事务的处理方式。
  • 是否有显式地请求事务回滚的代码。
  • 数据库约束是否可能导致事务失败。

此外,了解你使用的框架或容器的事务管理策略和配置也是非常重要的。

捕获了运行时异常但期望事务继续

在大多数现代Java框架(如Spring)中,运行时异常(RuntimeException 及其子类)默认会导致事务回滚。这是因为运行时异常通常表示程序中的错误,这些错误可能破坏了数据的完整性或一致性,因此框架选择自动回滚事务以避免潜在的问题。

然而,如果你捕获了运行时异常但仍然希望事务继续(即不触发回滚),你需要采取一些额外的步骤来确保这一点。但是,请注意,这种做法通常是不推荐的,因为它可能隐藏了潜在的问题并导致数据不一致。

在Spring框架中,你可以通过以下几种方式来处理这个问题:

  1. 使用@Transactional(noRollbackFor = ...)@Transactional(noRollbackForClassName = ...)

    你可以在服务层的方法上使用@Transactional注解,并通过noRollbackFornoRollbackForClassName属性来指定哪些异常不应该导致事务回滚。但是,请注意这些属性只接受编译时异常(即那些继承自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,请不要回滚事务。” 它并不依赖于你是否在方法内部捕获了这个异常。

  1. 编程式事务管理

    如果你需要更细粒度的控制,可以考虑使用编程式事务管理。这允许你在代码中显式地开始、提交或回滚事务。但是,这种方法更加复杂,并且通常不推荐用于服务层方法,因为它与声明式事务管理相比更加繁琐且容易出错。

  2. 重新考虑异常处理策略

    最后,你可能需要重新考虑你的异常处理策略。通常,如果一个运行时异常表明数据可能已经处于不一致的状态,那么回滚事务是保护数据完整性的正确做法。如果你的业务逻辑允许在发生特定运行时异常时继续执行(尽管这很少见),你可能需要重新设计你的业务逻辑或异常处理逻辑,以确保数据的一致性和完整性不会受到影响。

总的来说,虽然你可以通过@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&#xff1a; #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最主要区别是一次性能计算多少字节数据&#xff0c;如果计算的数额不超过 32 位数字的情况下&#xff0c;32 位和 64 位 CPU 之间没什么区别的&#xff0c;只有当计算超过 32 位数字的情况下&#…...

springboot船舶维保管理系统--论文源码调试讲解

第二章 相关技术 本次开发船舶维保管理系统使用的是Vue进行程序开发&#xff0c;船舶维保管理系统的数据信息选择MySQL数据库进行存放。 2.1 VUE介绍 Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是&#xff0c;Vue…...

【机器学习西瓜书学习笔记——神经网络】

机器学习西瓜书学习笔记【第五章】 第五章 神经网络5.1神经元模型5.2 感知机与多层网络学习感知机学习率成本/损失函数梯度下降 5.3 BP神经网络&#xff08;误差逆传播&#xff09;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. 禁用状态 二、大小&#xff08;Sizes&#xff09;1. 小尺寸&#xff08;Small&#xff09;2. 大尺寸&#xff08;Large&#xff09; 三、颜色&#xff08;Colors&#xff09;1. 主题颜色2. 自定义颜色 四、高级用法和最佳实践1. 无障碍性&#xff08;A…...

51单片机-第七节-DS1302实时时钟

一、DS1302介绍&#xff1a; 实时时钟芯片&#xff0c;可对年&#xff0c;月&#xff0c;日&#xff0c;周&#xff0c;时&#xff0c;分&#xff0c;秒计时&#xff0c;是一种集成电路。 二、DS1302原理&#xff1a; 1.寄存器定义&#xff1a; Command&#xff1a;操作模式…...

Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序

Java毕业设计 基于SSM和Vue的图书馆座位预约系统小程序 这篇博文将介绍一个基于SSM框架和Vue开发的图书馆座位预约系统微信小程序&#xff0c;适合用于Java毕业设计。 功能介绍 用户 登录 注册 首页 图片轮播 关于我们 公告信息 图书馆信息 图书馆详情 预约选座 收藏 …...

【C++11】:lambda表达式function包装器

目录 前言一&#xff0c;可变参数模板1.1 简单认识1.2 STL容器中的empalce系列相关接口 二&#xff0c;lambda表达式2.1 lambda表达式语法2.2 探索lambda底层 三&#xff0c;包装器3.1 function包装器3.2 bind 四&#xff0c;类的新功能4.1 默认成员函数4.2 关键字default4.3 关…...

[io]进程间通信 -有名、无名管道 区别

有名管道和无名管道的区别 无名管道有名管道 使用场景 亲缘关系进程不相关的任意进程特点 1.固定读端fd[0]写端fd[1] 2.文件IO进行操作 3.不支持lseek&#xff08;&#xff09;操作 4.数据存储在内核空间 1.文件系统中存在管道文件 2.文件IO操作 3.不支持lseek 4.先进先出 5.数…...

pywinauto:Windows桌面应用自动化测试(七)

前言 上一篇文章地址&#xff1a; pywinauto&#xff1a;Windows桌面应用自动化测试&#xff08;六&#xff09;-CSDN博客 下一篇文章地址&#xff1a; 暂无 一、实战常用方法 1、通过Desktop快速获取窗口 通过之前章节我们了解到控制应用的方法为Application&#xff0…...

XCTF-web-easyupload

试了试php&#xff0c;php7&#xff0c;pht&#xff0c;phtml等&#xff0c;都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接&#xff0c;得到flag...

【入坑系列】TiDB 强制索引在不同库下不生效问题

文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

遍历 Map 类型集合的方法汇总

1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

AtCoder 第409​场初级竞赛 A~E题解

A Conflict 【题目链接】 原题链接&#xff1a;A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串&#xff0c;只有在同时为 o 时输出 Yes 并结束程序&#xff0c;否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...

五年级数学知识边界总结思考-下册

目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解&#xff1a;由来、作用与意义**一、知识点核心内容****二、知识点的由来&#xff1a;从生活实践到数学抽象****三、知识的作用&#xff1a;解决实际问题的工具****四、学习的意义&#xff1a;培养核心素养…...

基础测试工具使用经验

背景 vtune&#xff0c;perf, nsight system等基础测试工具&#xff0c;都是用过的&#xff0c;但是没有记录&#xff0c;都逐渐忘了。所以写这篇博客总结记录一下&#xff0c;只要以后发现新的用法&#xff0c;就记得来编辑补充一下 perf 比较基础的用法&#xff1a; 先改这…...

土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等

&#x1f50d; 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术&#xff0c;可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势&#xff0c;还能有效评价重大生态工程…...

高防服务器能够抵御哪些网络攻击呢?

高防服务器作为一种有着高度防御能力的服务器&#xff0c;可以帮助网站应对分布式拒绝服务攻击&#xff0c;有效识别和清理一些恶意的网络流量&#xff0c;为用户提供安全且稳定的网络环境&#xff0c;那么&#xff0c;高防服务器一般都可以抵御哪些网络攻击呢&#xff1f;下面…...

HDFS分布式存储 zookeeper

hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架&#xff0c;允许使用简单的变成模型跨计算机对大型集群进行分布式处理&#xff08;1.海量的数据存储 2.海量数据的计算&#xff09;Hadoop核心组件 hdfs&#xff08;分布式文件存储系统&#xff09;&a…...

windows系统MySQL安装文档

概览&#xff1a;本文讨论了MySQL的安装、使用过程中涉及的解压、配置、初始化、注册服务、启动、修改密码、登录、退出以及卸载等相关内容&#xff0c;为学习者提供全面的操作指导。关键要点包括&#xff1a; 解压 &#xff1a;下载完成后解压压缩包&#xff0c;得到MySQL 8.…...