认识 spring 中的事务 与 事务的传播机制


前言

本篇介绍spring中事务的实现方式,如何实现声明式事务,对事物进行参数的设置,了解事务的隔离级别和事务的传播机制;如有错误,请在评论区指正,让我们一起交流,共同进步!


文章目录

  • 前言
  • [1. spring中事务实现的方式](#1. spring中事务实现的方式)
  • [2. 实现声明式事务](#2. 实现声明式事务)
  • [3. 设置@Transactional的参数](#3. 设置@Transactional的参数)
  • [4. spring 的事务隔离级别](#4. spring 的事务隔离级别)
  • [5. 事务的传播机制 - spring](#5. 事务的传播机制 - spring)
  • 总结

本文开始

1. spring中事务实现的方式

spring中事务实现的方式:

① 编程式事务 - 手动 写代码去操作事务

实现主要过程:开启事务 + 提交事务 + 回滚事务;- 都需要手动

② 声明式事务 - 使用注释操作事务 - 自动

实现主要过程:进入方法自动开启事务,执行完方法自动提交事务,出现错误,自动回滚事务;- 让事务自动开启+自动提交事务

事务目的:实现事务,当程序异常时,会进行回滚操作;

手动实现事务太过于麻烦,一般都使用声明式事务(自动),下面就介绍一下声明式事务;

2. 实现声明式事务

实现方式:

① 在要执行的方法(事务)上,加上注释@Transactional; - 推荐使用

② 在类上加注释@Transactional;

java 复制代码
	//在方法上声明事务
	@Transactional
    public int add() {
		//......
	}
	//在类上声明事务
	@Transactional
	public class User {
		//......
	}

3. 设置@Transactional的参数

设置参数的方式:在注释括号中添加参数 - @Transactional(xxx)

@Transactional的参数:

  • value 和 transactionManager : 指定选择哪个事务管理器
  • propagation: 事务的传播行为
  • islation: 设置事务的隔离级别
  • readOnly: 设置事务的为 只读事务
  • timeout: 设置事务的超时时间

4. spring 的事务隔离级别

添加参数示例:@Transactional(islation = Isolatino.DEFAULT)

① Isolatino.DEFAULT: 事务的默认隔离级别 - 以客户端连接事务的隔离级别为主;

② Isolatino.READ_UNCOMMITTED: 读未提交

③ Isolatino.READ_COMMITTED:读已提交

④ Isolatino.REPEATABLE_READ: 可重复读

⑤ Isolatino.SERIALIZABLE_READ: 串行化

客户端可以设置数据库隔离级别:

spring 可认为是一个客户端,可以设置数据库隔离级别;

当前连接的事务隔离级别,也就是spring客户端的隔离级别;

默认事务隔离级别 与 当前连接(spring)的事务隔离级别 默认是一样的;

数据库隔离级别以当前spring设置的事务隔离级别为准,如果没设置就是默认的事务隔离级别;

设置当前连接的事务(当前spring客户端)隔离级别:

sql 复制代码
//查询事务 - 此命名使用mysql 5.7版本
select @@global.tx_isolation,@@tx_isolation;
//设置事务隔离级别
set session transaction isolation level SERIALIZABLE

问题:设置@Transactional,程序出现异常,但被 try catch捕获,虽捕获但没有处理异常(抛出异常),导致事务没有回滚;

解决方式:让事务在异常情况下也可以实现回滚;

1.抛出异常 - throw e

  1. 手动回滚事务: TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();;

5. 事务的传播机制 - spring

什么是事务的传播机制?

事务的传播机制:规定多个事务相互调用,事务的执行行为的机制; (执行行为 = 各方法传递的行为)

事务的传播机制:

  • Propagation.REQUIRED: 默认事务传播机制,当前存在事务,就加入事务;当前没有事务,就创建一个新的事务;
  • Propagation.SUPPORT S: 当前存在事务,就加入事务;当前没有事务,就以非事务方式继续运行;
    【注】以非事务方式运行,事务调用链上遇到异常,不关注,不会再进行回滚操作;(不再是一个整体,各执行各的)
  • Propagation.MANDATORY: 当前存在事务,就加入事务;当前没有事务,就抛出异常;
  • Propagation.REQUIRES_NEW:创建一个新的事务,如果当前存在事务,就把当前事务挂起;- 开启自己新的事务,且相互独立;
  • Propagation.NOT_SUPPORTED: 以非事务方式运行,如果当前存在事务,就把当前事务挂起;
  • Propagation.NEVER: 以非事务方式运行,如果当前存在事务,就抛出异常;
  • Propagation.NESTED: 当前存在事务,就创建一个事务作为嵌套事务来运行;如果没有当前事务,相当于默认事务Propagation.REQUIRED;- 嵌套事务在嵌套进事务时会标记保存点,嵌套事务出现异常,会回到标记点(回滚),不影响整个事务链(存档);

【注】事务c异常,在事务c中做了手动回滚事务的操作;该异常不会被事务a感知到;


总结

✨✨✨各位读友,本篇分享到内容如果对你有帮助给个👍赞鼓励一下吧!!
感谢每一位一起走到这的伙伴,我们可以一起交流进步!!!一起加油吧!!!

相关推荐
tangliang_cn5 分钟前
java入门 自定义springboot starter
java·开发语言·spring boot
程序猿阿伟6 分钟前
《智能指针频繁创建销毁:程序性能的“隐形杀手”》
java·开发语言·前端
Grey_fantasy16 分钟前
高级编程之结构化代码
java·spring boot·spring cloud
新知图书17 分钟前
Rust编程与项目实战-模块std::thread(之一)
开发语言·后端·rust
弗锐土豆23 分钟前
工业生产安全-安全帽第二篇-用java语言看看opencv实现的目标检测使用过程
java·opencv·安全·检测·面部
Elaine20239123 分钟前
零碎04 MybatisPlus自定义模版生成代码
java·spring·mybatis
盛夏绽放38 分钟前
Node.js 和 Socket.IO 实现实时通信
前端·后端·websocket·node.js
小小大侠客40 分钟前
IText创建加盖公章的pdf文件并生成压缩文件
java·pdf·itext
一二小选手43 分钟前
【MyBatis】全局配置文件—mybatis.xml 创建xml模板
xml·java·mybatis