看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化)

本文主要是介绍看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对于不同的事务,采用不同的隔离级别分别有不同的现象。主要有下面3种:

1、脏读(dirty read):一个事务可以读取另一个尚未提交事务的修改数据。

2、不可重复读(nonrepeatable read)是指在数据库访问中,一个事务范围内两个相同的查询却返回了不同数据。

3、幻像读(phantom read):在同一事务中,同一查询多次进行时候,由于其他插入操作(insert)的事务提交,导致每次返回不同的结果集。

事务的隔离级别:

隔离级别脏读不可重复读幻读含义

read uncommitted(未提交读)

允许你读取别人未提交的事务,会出现脏读、幻读、不可重复读
read committed(读已提交)对事务已经提交的数据进行读取。解决了脏读。会出现幻读和不可重复度
repeatable read(重复读)在一个事务中。对相同字段条件读取数据都是一致的。但此类会出现幻读
serializable(序列化)完全服从数据库的ACID,不会出现幻读、不可重复读、脏读。但开启这类级别会非常消耗性能。它是典型的通过完全锁定在事务中涉及到数据库表的来完成的

其实针对文字性的东西。我们程序员不太好理解。就算理解了,过段时间也就忘了。所以还是要去做实验,让自己清楚。原来在这个场景下。这个概念 是这样的。

那让我们一起开启探索。mysql数据库的各个隔离级别的具体含义

准备两个窗口。一个修改数据的窗口,一个查询数据的窗口

1、read uncommitted 

模拟读未提交

首先设置数据库的隔离级别为读未提交

set  session transaction isolation level  read UNCOMMITTED

用命令 SELECT @@tx_isolation;查询下设置的级别

因为我是用navicat Premium工具连接的数据库。开启两个查询窗口(切记这两个查询窗口都需要设置隔离级别

在修改数据的窗口执行以下操作:

1、开启事务(begin)

2、修改数据disablestate设置为7。这时不要提交事务

3、用另个事务去查询数据,结果disablestate数据为7

果然读取到了,未提交的数据。所以也验证了未提交读。你修改了数据,但是事务还没来及提交。竟然被人家读取了

 2、read committed

按照同样的步骤。把数据库的隔离级别设置为读已提交

 set  session transaction isolation level read committed

 

在修改数据的窗口执行以下操作: 

1、开启事务(begin)

 2、修改数据设置disablestate为8

 update user_account set disablestate='8' where id='3';

此时还未提交事务。去另个窗口去查询下数据读取到的disablestate为7

 用了读已提交,不会读取到未提交的事务的数据。解决了脏读。但是不可重复读这个是什么呢?

看我的sql

 在一个事务中。读取两次。首先修改数据。不提交事务。执行第二行sql。

读取到disablestate为7。在修改的数据的窗口。提交事务,执行第三行sql

哦。数据变了。这就是所谓的不可重复读。在一个事务中。重复读取一条数据。出现了不同的结果 。解决不可重复读。当然用可重复读。

3、repeatable read

按照同样的步骤。把数据库的隔离级别设置为可重读

set  session transaction isolation level  REPEATABLE READ
 

在修改数据的窗口执行以下操作:

1、开启事务

2、修改数据。把disablestate设置为9,先不要提交事务

 在查询窗口中执行

两次查询都是之前的数据8。所以你理解了可重复读了吗?但是这个级别解决不了幻读。你get到了吗?用相同方法去尝试模拟幻读吧

序列化就不做过多演示了。序列化可以解决幻读。但是这个隔离级别性能消耗太大。基本不用 

这篇关于看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

SpringBoot+Redis防止接口重复提交问题

《SpringBoot+Redis防止接口重复提交问题》:本文主要介绍SpringBoot+Redis防止接口重复提交问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录前言实现思路代码示例测试总结前言在项目的使用使用过程中,经常会出现某些操作在短时间内频繁提交。例

如何在Mac上彻底删除Edge账户? 手动卸载Edge浏览器并清理残留文件技巧

《如何在Mac上彻底删除Edge账户?手动卸载Edge浏览器并清理残留文件技巧》Mac上的Edge账户里存了不少网站密码和个人信息,结果同事一不小心打开了,简直尴尬到爆炸,想要卸载edge浏览器并清... 如果你遇到 Microsoft Edge 浏览器运行迟缓、频繁崩溃或网页加载异常等问题,可以尝试多种方

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co