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

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

相关推荐
喝养乐多长不高19 小时前
JAVA微服务脚手架项目详解(三)
java·大数据·微服务·文件·地图·oss
万邦科技Lafite19 小时前
1688图片搜索商品API接口(item_search_img)使用指南
java·前端·数据库·开放api·电商开放平台
自在极意功。19 小时前
SQL查询语句深度解析:从基础到进阶,写出高效优雅的SQL!
数据库·sql
落落落sss19 小时前
java实现排序
java·数据结构·算法
north_eagle19 小时前
MySQL 业务数据,报表方案
大数据·数据库
czhc114007566319 小时前
c# 1121 构造方法
java·javascript·c#
Z***258019 小时前
Java爬虫框架
java·开发语言·爬虫
r***123819 小时前
Spring boot启动原理及相关组件
数据库·spring boot·后端
晓华-warm19 小时前
Warm-Flow 1.8.4 票签新增多种通过率策略!
java·中间件·流程图·jar·开源软件·工作流
数据库学啊19 小时前
大数据场景下时序数据库选型指南:TDengine为什么凭借领先的技术和实践脱颖而出?
大数据·数据库·时序数据库·tdengine