一文玩转@Transactional SpringAOP声明式事务

2024-05-12 05:28

本文主要是介绍一文玩转@Transactional SpringAOP声明式事务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.使用详解

`@Transactional` 注解是Spring框架中用于声明式事务管理的核心注解之一。通过在方法或类上添加 `@Transactional` 注解,你可以告诉Spring在调用该方法时启用事务管理。以下是 `@Transactional` 注解的使用方法及参数详解:

1. 在方法上使用:

@Transactionalpublic void someTransactionalMethod() {// 这个方法的执行将在一个事务中// 任何数据库操作都会在这个方法执行的同一个事务中}

2. 在类上使用:

@Service@Transactionalpublic class SomeTransactionalService {// 在这个类中所有的方法调用都将在事务中执行}

3. 参数:

   - readOnly:指定事务是否为只读。如果设置为 `true`,表示该事务只读取数据,不会对数据进行修改。默认值为 `false`。

@Transactional(readOnly = true)public void readOnlyMethod() {// 仅读取数据的操作}

   - timeout:指定事务的超时时间,单位为秒。如果在指定时间内事务没有完成,将会被回滚。默认值为 `TransactionDefinition.TIMEOUT_DEFAULT`,表示使用默认的超时时间。

@Transactional(timeout = 60) // 60秒超时public void methodWithTimeout() {// 可能会耗时很长的操作}

   - rollbackFor和 noRollbackFor:指定在哪些异常发生时事务应该回滚或不回滚。

@Transactional(rollbackFor = {SQLException.class, IOException.class})public void methodThatMayThrowExceptions() throws SQLException, IOException {// 可能会抛出SQLException或IOException的操作}

   - propagation:指定事务的传播行为。例如,是否要在当前事务内加入已存在的事务,或者要开启一个新的事务。

@Transactional(propagation = Propagation.REQUIRED)public void methodWithPropagation() {// 这个方法将会在一个事务中执行,如果当前没有事务,则会开启一个新的事务}

   这些是最常用的 `@Transactional` 注解的参数。通过合理配置这些参数,你可以灵活地管理你的事务行为。

2.修改事务的隔离级别

在Spring中,默认的事务隔离级别是数据库的默认级别。通常情况下,大多数数据库的默认事务隔离级别是**读已提交(Read Committed)**。

事务隔离级别决定了一个事务对于其他事务的可见性以及对其他事务的影响。不同的隔离级别会对并发访问数据库时出现的问题产生不同的影响。

在Spring中,你可以通过设置 `@Transactional` 注解的 `isolation` 属性来指定事务的隔离级别,例如:


@Transactional(isolation = Isolation.READ_UNCOMMITTED)
public void someTransactionalMethod() {// 这个方法的事务隔离级别为读未提交
}

`Isolation` 是一个枚举类型,包含了不同的隔离级别选项,例如 `READ_UNCOMMITTED`、`READ_COMMITTED`、`REPEATABLE_READ` 和 `SERIALIZABLE` 等。通过显式地设置 `isolation` 属性,你可以覆盖默认的隔离级别。

但需要注意的是,如果你没有显式地指定事务的隔离级别,Spring 将使用底层数据库的默认隔离级别作为默认值。

3.底层实现

`@Transactional` 注解是Spring框架中用于声明式事务管理的核心注解之一。它的实现主要依赖于Spring的事务管理器和AOP(面向切面编程)机制。

以下是对 `@Transactional` 注解在Java源码中的简要解析:

1. 源码位置:

   `@Transactional` 注解的源码位于 Spring Framework 项目中的 `org.springframework.transaction.annotation` 包下。

2. 注解定义:

   `@Transactional` 注解是一个元注解,它的定义如下:

@Target({ElementType.METHOD, ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @interface Transactional {// 属性定义,例如 isolation、propagation、timeout、readOnly 等}

3. 属性:

   `@Transactional` 注解支持多个属性,用于配置事务的行为。一些常用的属性包括:

   - `isolation`:指定事务的隔离级别。
   - `propagation`:指定事务的传播行为。
   - `timeout`:指定事务的超时时间。
   - `readOnly`:指定事务是否为只读事务。
   - `rollbackFor` 和 `noRollbackFor`:指定在哪些异常发生时事务应该回滚或不回滚。

4. AOP代理:

   Spring使用AOP机制来实现 `@Transactional` 注解。在运行时,Spring会在方法执行前后织入事务管理相关的代码,以确保方法在事务的上下文中执行。

   这意味着 `@Transactional` 注解可以将事务管理从业务逻辑代码中分离出来,使得代码更加清晰和模块化。

5. 事务管理器:

   `@Transactional` 注解的实现依赖于Spring的事务管理器。在使用 `@Transactional` 注解时,你需要在Spring的配置文件中配置事务管理器,以便让Spring知道如何管理事务。

   Spring支持多种事务管理器,包括基于JDBC的事务管理器、基于JTA的事务管理器、以及基于Hibernate等ORM框架的事务管理器。

6. 源码实现:

   `@Transactional` 注解的具体实现比较复杂,涉及到Spring的AOP、事务拦截器、事务管理器等多个模块。它主要通过AOP机制来拦截带有 `@Transactional` 注解的方法调用,并在方法执行前后启动和提交事务。

总的来说,`@Transactional` 注解是Spring框架中用于声明式事务管理的重要工具,它使得在Spring应用中使用事务变得简单和便捷。

这篇关于一文玩转@Transactional SpringAOP声明式事务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

一文详解kafka开启kerberos认证的完整步骤

《一文详解kafka开启kerberos认证的完整步骤》这篇文章主要为大家详细介绍了kafka开启kerberos认证的完整步骤,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、kerberos安装部署二、准备机器三、Kerberos Server 安装1、配置krb5.con

一文详解Nginx的强缓存和协商缓存

《一文详解Nginx的强缓存和协商缓存》这篇文章主要为大家详细介绍了Nginx中强缓存和协商缓存的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、强缓存(Strong Cache)1. 定义2. 响应头3. Nginx 配置示例4. 行为5. 适用场景二、协商缓存(协