Spring事务的隔离级别

使用事务隔离级别可以控制并发事务在同时执行时的某种行为。

前言:

在学习Spring事务隔离级别前我们先了解一下什么是脏读,幻读,不可重复读。

脏读:

一个事务读到另一个事务未提交的更新数据,所谓脏读,就是指事务A读到了事务B还没有提交的数据,比如银行取钱,事务A开启事务,此时切换到事务B,事务B开启事务->取走100元,此时切换回事务A,事务A读取的肯定是数据库里面的原始数据,因为事务B取走了100块钱,井没有提交,数据库里面的账务余额街定还是原始余额,这就是脏读。

幻读:

是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么。以后就会发生操作第一个重务的用户发现表中还有没有修改的数据行,就好像发生了幻觉一样。

不可重复的:

在一个事务里面的操作中发现了未被操作的效据 比如说在同一个事务中先后执行两条一横一样的select语句,明间在此次亚务中没有执行过任何DDL语句,但先后得到的结果不一教,这就是不可重复读。

一、DEFAULT(默认的事务隔离级别)

使用当前数据的默认隔离级别,MySql默认采用可重复读隔离级别,Oracle默认采用读已提交隔离级别。

二、READ_UNCOMMITTED(读未提交)

最低的隔离级别,允许读取尚未提交的数据变更,就是上面提到的脏读。

这种隔离级别可能导致脏读,幻读,不可重复读。

三、READ_COMMITTED(读已提交)

允许读取并发事务已经提交的数据,该隔离级别的事务能读取到已经提交事务的数据,因此它不会有脏读问题。但由于在事务的执行中可以读取到其他事务提交的结果,所以在不同时间的相同 SQL 查询中,可能会得到不同的结果,这种现象叫做不可重复读。

这种隔离级别可能阻止脏读,但是幻读和不可重复读仍有可能发生。

四、REPEATABLE_READ(可重复读)

它能确保同一事务多次查询的结果一致。但也会有新的问题,比如此级别的事务A正在执行时,另一个事务B成功的插入了某条数据,但因为A每次查询的结果都是一样的,所以会导致查询不到这条数据,B重复插入时又失败(因为唯一约束的原因)。明明在A查询不到这条信息,但B就是插入不进去,就是我们上面提到的幻读

这种隔离级别可能阻止脏读和不可重复读,但是幻读仍有可能发生。

五、SERIALIZABLE(串行化)

最高的事务隔离级别,完全服从ACID的隔离级别,它会强制事务排序,所有事务依次逐个执行,使之不会发生冲突,从而解决了脏读、不可重复读和幻读问题,但因为执行效率低,严重影响系统性能,所以真正使用的场景并不多。

这种隔离级别可能阻止脏读,幻读和不可重复读。

相关推荐
無限進步D5 小时前
Java 运行原理
java·开发语言·入门
難釋懷5 小时前
安装Canal
java
是苏浙5 小时前
JDK17新增特性
java·开发语言
不光头强5 小时前
spring cloud知识总结
后端·spring·spring cloud
Mike117.5 小时前
GBase 8a 日期边界写法和时间窗口取数偏差
数据库
SPC的存折6 小时前
1、Redis数据库基础
linux·运维·服务器·数据库·redis·缓存
阿里加多8 小时前
第 4 章:Go 线程模型——GMP 深度解析
java·开发语言·后端·golang
likerhood8 小时前
java中`==`和`.equals()`区别
java·开发语言·python
小小李程序员8 小时前
Langchain4j工具调用获取不到ThreadLocal
java·后端·ai
zs宝来了9 小时前
AQS详解
java·开发语言·jvm