IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL学习(2)- 事务的隔离级别 -> 正文阅读

[大数据]MySQL学习(2)- 事务的隔离级别

前言

我们知道MySQL的事务四个特性,原子性、一致性、隔离性、持久性,今天我们来重点学习隔离性,这也是面试中经常会问到的问题。

1 事务并发所带来的问题

在隔离性之前先看事务并发时会产生什么问题。

1.1 脏读

脏读是事务A读取了事务B未提交的数据,然后事务B并没有提交事务而是回滚了事务,这样就会造成事务A读取了一个无效且没有意义的数据。

简而言之:一个事务读取了另一个事务未提交的数据,在读未提交级别会有这样的情况。

1.2 不可重复读

不可重复读是事务A中相同的查询,产生了不同的结果。
造成这种结果的原因是事务A第一次查询之后,事务B修改了数据并且提交事务,这个时候事务A又查询了一次数据,这个时候读取到了事务B修改的结果。

简而言之:一个事务读取了另一个事务已提交的数据,在读未提交和读已提交都会有不可重复度的问题。

1.3 幻读

The so-called phantom problem occurs within a transaction when the same query produces different sets of rows at different times.

官网开头有这样一句话,大意是:当同一查询在不同时间生成不同的行集时,事务中就会出现所谓的幻影问题。
具体操作:对于两个事务T1、T2,T1从表中读取数据,然后T2进行了INSERT操作并提交,当T1’再次读取的时候,结果不一致的情况发生。
简而言之:一个事务读取了另一个事务新插入的行,导致两次相同查询不同。
参考文档:官方文档幻读说明

1.4 实践

1.4.1 基础准备

建表语句:

CREATE TABLE `t` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `a` int(11) DEFAULT NULL,
  `b` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

新建数据:
在这里插入图片描述

1.4.2 不可重复读实践

实践之前先更改下隔离级别

#查询数据隔离级别
SELECT @@tx_isolation;

#设置隔离级别为读已提交
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
session Asession B
T1begin;
select * from t;
T2update t set b = 300 where a = 30;
T3select * from t;

结果1:
在这里插入图片描述
结果2:
在这里插入图片描述
可以看到事务A中,两次相同的查询结果并不相同,原因是事务A读了事务B修改的数据。

1.4.3 幻读实践

实践之前先更改下隔离级别

#查询数据隔离级别
SELECT @@tx_isolation;

#设置隔离级别为读已提交
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
session Asession B
T1begin;
select * from t;
T2insert into t (a,b) values (60,60);
T3select * from t;

结果1:
在这里插入图片描述
结果2:
在这里插入图片描述
可以看到事务A中,两次相同的查询结果并不相同,原因是事务A读了事务B新增的数据,这新增的行为幻影行。

2 隔离级别

事务隔离是数据库处理的基础之一。隔离级别是在多个事务同时进行更改和执行查询时微调结果的性能和可靠性、一致性和可再现性之间的平衡的设置。

2.1 Read Uncommitted(读取未提交内容)

  • 在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。
  • 读取未提交的数据,也被称之为脏读(Dirty Read)。

2.2 Read Committed(读取提交内容)

它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。

2.3 Repeatable Read(可重复读)

这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。

3.4 Serializable(可串行化)

这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。在这个级别,可能导致大量的超时现象和锁竞争。

3.5 四种隔离级别

事务隔离级别脏读不可重复读幻读
读未提交(read-uncommitted)
读已提交(read-committed)
可重复读(repeatable-read)
串行化(serializable)
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-28 11:22:04  更:2021-11-28 11:22:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 14:02:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码