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

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

相关推荐
电商数据girl5 分钟前
酒店旅游类数据采集API接口之携程数据获取地方美食品列表 获取地方美餐馆列表 景点评论
java·大数据·开发语言·python·json·旅游
CircleMouse5 分钟前
基于 RedisTemplate 的分页缓存设计
java·开发语言·后端·spring·缓存
ktkiko1112 分钟前
顶层架构 - 消息集群推送方案
java·开发语言·架构
Ailovelearning13 分钟前
neo4j框架:ubuntu系统中neo4j安装与使用教程
数据库·neo4j
zybsjn17 分钟前
后端系统做国际化改造,生成多语言包
java·python·c#
Unity官方开发者社区1 小时前
《Cryptical Path》开发诀窍:像玩游戏一样开发一款类Rogue游戏
java·游戏·玩游戏
_星辰大海乀1 小时前
表的设计、聚合函数
java·数据结构·数据库·sql·mysql·数据库开发
IT成长史1 小时前
deepseek梳理java高级开发工程师微服务面试题-进阶版
java·spring cloud·微服务
zkmall1 小时前
Java + 鸿蒙双引擎:ZKmall开源商城如何定义下一代B2C商城技术标准?
java·开源·harmonyos
陌路物是人非1 小时前
uniapp取消浏览自动填充
java·服务器·uni-app