@Transaction注解详情解释

2024-05-12 14:36

本文主要是介绍@Transaction注解详情解释,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念:

        @Transactional注解是Spring框架提供的一个用于声明式事务管理的注解,方便我们管理事务,保证数据的一致性与可靠性。

事务4个基本特性:

        原子性:一个事务要不全部(sql)执行;要不都不执行(回滚)。

        一致性:事务执行前后数据库的状态保存一致。(数据完整性,约束,预期一致)

        隔离性:多个事务并发执行时,事务的执行时互不干扰的。

        持久性:事务一旦提交,所做的操作,永久保存在数据库中。

使用:

        可以放在方法上,可以放在类上。

类上:

        表示该类下面所有的public方法都用相同的事务属性信息。

方法上:

        表示该方法使用当前的事务属性信息。

属性:

        propagation传播行为、isolation隔离级别、timeout超时时间、readOnly是否为只读事务、rollbackFor指定回滚异常类型、noRollbackFor抛出指定异常类型,不混滚事务。

propagation传播行为

  1. REQUIRED (默认)

    • 如果当前存在事务,则加入该事务;
    • 如果当前没有事务,则创建一个新的事务。
  2. SUPPORTS

    • 如果当前存在事务,则加入该事务;
    • 如果当前没有事务,则以非事务的方式继续运行。
  3. MANDATORY

    • 如果当前存在事务,则加入该事务;
    • 如果当前没有事务,则抛出异常。
  4. REQUIRES_NEW

    • 暂停当前存在的事务(如果有的话),并创建一个新的事务,将自己的事务和这个新事务关联(如果支持的话)。
    • 注意:即使外层事务发生异常被回滚,也不会影响内层REQUIRES_NEW的事务。
  5. NOT_SUPPORTED

    • 以非事务的方式运行,如果当前存在事务,则把当前事务挂起。
  6. NEVER

    • 以非事务的方式运行,如果当前存在事务,则抛出异常。
  7. NESTED

    • 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,其行为与 REQUIRED 相同。
    • 嵌套事务是依赖于外部事务的,外部事务失败,嵌套事务也会失败,但嵌套事务的失败不会影响外部事务。

注意:NESTED 和 REQUIRES_NEW 之间的主要区别在于,NESTED 的事务是依赖于外部事务的,而 REQUIRES_NEW 则会完全独立地开始一个新的事务。

在使用 @Transactional 注解时,要特别注意方法的调用方式。例如,一个标记为 @Transactional 的方法被同一个类中的另一个方法直接调用时,事务的边界可能不会按照预期工作,因为Spring AOP默认是基于接口的代理。如果你直接调用同一个类中的方法,那么代理不会生效,因此事务管理也就不会工作。在这种情况下,你可能需要将该方法移动到另一个类中,或者使用编程式事务管理来手动控制事务。

isolation隔离级别

  1. Isolation.DEFAULT:使用底层数据库默认的隔离级别。这是默认值。
  2. Isolation.READ_UNCOMMITTED(读未提交):允许读取并发事务尚未提交的数据。这种隔离级别可能会导致脏读、不可重复读和幻读。
  3. Isolation.READ_COMMITTED(读已提交):对同一字段的多次读取结果都是一致的。这是大多数数据库系统的默认隔离级别(但不是MySQL的默认级别)。它防止了脏读,但可能出现不可重复读和幻读。
  4. Isolation.REPEATABLE_READ(可重复读):对同一字段的多次读取结果都是一致的。这是MySQL的默认隔离级别。它解决了脏读问题,并且保证对同一字段的多次读取结果都是一致的。但是,它无法解决幻读问题。
  5. Isolation.SERIALIZABLE(可串行化):最高的隔离级别,所有的事务依次逐个执行,这样事务之间就不可能产生干扰。但是,这将导致大量的事务等待无法并发执行,从而降低系统的吞吐量。

失效场景

方法不是 public 的

如果 @Transactional 注解应用在一个非 public 修饰的方法上,它将不会生效。这是因为 Spring AOP(面向切面编程)在代理目标方法时,只能拦截 public 方法。

当前类没有被 Spring 容器托管

如果类没有被 Spring 容器管理(例如,没有使用 @Service@Component 等注解),那么 @Transactional 注解也不会生效。

异常被捕获

如果在事务方法内部捕获了异常并且没有重新抛出,那么 Spring 将不会知道事务应该回滚。

数据库不支持事务

如果你正在使用一个不支持事务的数据库或数据库引擎(例如,MySQL 的 MyISAM 引擎),那么 @Transactional 注解也不会生效。

使用了错误的事务传播机制

@Transactional 注解有一个 propagation 属性,用于指定事务的传播行为。如果使用了错误的事务传播机制,可能会导致事务不按照预期的方式工作。

这篇关于@Transaction注解详情解释的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

嵌入式技术的核心技术有哪些?请详细列举并解释每项技术的主要功能和应用场景。

嵌入式技术的核心技术包括处理器技术、IC技术和设计/验证技术。 1. 处理器技术    通用处理器:这类处理器适用于不同类型的应用,其主要特征是存储程序和通用的数据路径,使其能够处理各种计算任务。例如,在智能家居中,通用处理器可以用于控制和管理家庭设备,如灯光、空调和安全系统。    单用途处理器:这些处理器执行特定程序,如JPEG编解码器,专门用于视频信息的压缩或解压。在数字相机中,单用途

请解释Java Web应用中的前后端分离是什么?它有哪些好处?什么是Java Web中的Servlet过滤器?它有什么作用?

请解释Java Web应用中的前后端分离是什么?它有哪些好处? Java Web应用中的前后端分离 在Java Web应用中,前后端分离是一种开发模式,它将传统Web开发中紧密耦合的前端(用户界面)和后端(服务器端逻辑)代码进行分离,使得它们能够独立开发、测试、部署和维护。在这种模式下,前端通常通过HTTP请求与后端进行数据交换,后端则负责业务逻辑处理、数据库交互以及向前端提供RESTful

OpenStack:Glance共享与上传、Nova操作选项解释、Cinder操作技巧

目录 Glance member task Nova lock shelve rescue Cinder manage local-attach transfer backup-export 总结 原作者:int32bit,参考内容 从2013年开始折腾OpenStack也有好几年的时间了。在使用过程中,我发现有很多很有用的操作,但是却很少被提及。这里我暂不直接

OpenStack实例操作选项解释:启动和停止instance实例

关于启动和停止OpenStack实例 如果你想要启动和停止OpenStack实例时,有四种方法可以考虑。 管理员可以暂停、挂起、搁置、停止OpenStack 的计算实例。但是这些方法之间有什么不同之处? 目录 关于启动和停止OpenStack实例1.暂停和取消暂停实例2.挂起和恢复实例3.搁置(废弃)实例和取消废弃实例4.停止(删除)实例 1.暂停和取消暂停实例

spring—使用注解配置Bean

从Spring2.5开始,出现了注解装配JavaBean的新方式。注解可以减少代码的开发量,spring提供了丰富的注解功能,现在项目中注解的方式使用的也越来越多了。   ** 开启注解扫描          Spring容器默认是禁用注解配置的。打开注解扫描的方式主要有两种: <context:component-scan>组件扫描和<context:annotation

Zuul详细解释

Zuul 是 Netflix 开源的 API 网关,广泛用于微服务架构中。它作为系统的前置网关,主要功能包括路由、负载均衡、限流、安全性管理等。Zuul 最常见的应用场景是作为反向代理,它接收所有来自客户端的请求,并将请求转发给后端的微服务,从而屏蔽了微服务的复杂性。Spring Cloud 集成了 Zuul,使其成为 Spring Cloud 微服务生态系统中的一个重要组件。 为什么使用 Zu

GetWay详细解释

Spring Cloud Gateway 是 Spring Cloud 提供的一款全功能 API 网关,作为微服务架构中的流量管理工具,提供了统一的入口来处理来自客户端的所有请求。它具有以下功能:路由请求、限流、熔断、监控、认证与授权等。 Spring Cloud Gateway 的设计基于 Spring 5.0 和 Spring Boot 2.0,并与 Spring WebFlux 深度集成,

rtklib.h : RTKLIB constants, types and function prototypes 解释

在 RTKLIB 中,rtklib.h 是一个头文件,包含了与 RTKLIB 相关的常量、类型和函数原型。以下是该头文件的一些常见内容和翻译说明: 1. 常量 (Constants) rtklib.h 中定义的常量通常包括: 系统常量: 例如,GPS、GLONASS、GALILEO 等系统的常量定义。 时间常量: 如一年、一天的秒数等。 精度常量: 如距离、速度的精度标准。 2. 类型

代码编译过程详细解释

代码编译过程是将源代码转化为计算机可以执行的机器代码的过程。这个过程分为几个主要阶段,每个阶段负责将源代码逐步转化为最终的可执行文件。以下是详细的编译过程解释: 1. 预处理 (Preprocessing) 功能:处理所有的预处理指令,如 #include、#define、#ifdef 等。 主要操作: 文件包含:替换 #include 指令,插入头文件的内容。宏替换:将 #define