千家信息网

Linux命令:MySQL系列之九--MySQL隔离级别及设置

发表于:2025-11-16 作者:千家信息网编辑
千家信息网最后更新 2025年11月16日,SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的。低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销。Read Uncommitted(读取
千家信息网最后更新 2025年11月16日Linux命令:MySQL系列之九--MySQL隔离级别及设置


SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的。低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销。
Read Uncommitted(读取未提交内容)

在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。读取未提交的数据,也被称之为脏读(Dirty Read)。
Read Committed(读取提交内容)

这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。这种隔离级别 也支持所谓的不可重复读(Nonrepeatable Read),因为同一事务的其他实例在该实例处理其间可能会有新的commit,所以同一select可能返回不同结果。
Repeatable Read(可重读)

这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的"幻影" 行。InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。

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

这四种隔离级别采取不同的锁类型来实现,若读取的是同一个数据的话,就容易发生问题。例如:

脏读(Drity Read):某个事务已更新一份数据,另一个事务在此时读取了同一份数据,由于某些原因,前一个RollBack了操作,则后一个事务所读取的数据就会是不正确的。

不可重复读(Non-repeatable read):在一个事务的两次查询之中数据不一致,这可能是两次查询过程中间插入了一个事务更新的原有的数据。

幻读(Phantom Read):在一个事务的两次查询中数据笔数不一致,例如有一个事务查询了几列(Row)数据,而另一个事务却在此时插入了新的几列数据,先前的事务在接下来的查询中,就会发现有几列数据是它先前所没有的。

在MySQL中,实现了这四种隔离级别,分别有可能产生问题如下所示:


下面,将利用MySQL的客户端程序,分别测试几种隔离级别。测试数据库为test,表为tx;表结构:

idint

num

int

两个命令行客户端分别为A,B;不断改变A的隔离级别,在B端修改数据。

(一)、将A的隔离级别设置为read uncommitted(未提交读)

mysql> SET tx_isolation='READ-UNCOMMITTED' 设定隔离级别为READ-UNCOMMITTED

在B未更新数据之前:

客户端A:

B更新数据:

客户端B:

客户端A:

经过上面的实验可以得出结论,事务B更新了一条记录,但是没有提交,此时事务A可以查询出未提交记录。造成脏读现象。未提交读是最低的隔离级别。

(二)、将客户端A的事务隔离级别设置为read committed(已提交读)

mysql> SET tx_isolation='READ-COMMITTED' 设定隔离级别为READ-COMMITTED

在B未更新数据之前:

客户端A:

B更新数据:

客户端B:

客户端A:

经过上面的实验可以得出结论,已提交读隔离级别解决了脏读的问题,但是出现了不可重复读的问题,即事务A在两次查询的数据不一致,因为在两次查询之间事务B更新了一条数据。已提交读只允许读取已提交的记录,但不要求可重复读。

(三)、将A的隔离级别设置为repeatable read(可重复读)

mysql> SET tx_isolation='REPEATABLE-READ' 设定隔离级别为REPEATABLE-READ

在B未更新数据之前:

客户端A:

B更新数据:

客户端B:

客户端A:

B插入数据:

客户端B:

客户端A:

由以上的实验可以得出结论,可重复读隔离级别只允许客户端读取已提交记录,并且必须是自己该客户端的事务提交后才能看到,其他客户端更新的并提交了的数据。这样也是会造成幻读,因为客户端事务提交前后所读取的数据可能不一样,如果其他客户端更新了数据,并提交了事务,那当前这个客户端没做任何操作,只是事务提交前后所读取的内容不一致造成幻读。

(四)、将A的隔离级别设置为 可串行化 (Serializable)

mysql> SET tx_isolation='SERIALIZABLEA' 设定隔离级别为SERIALIZABLEA

A端打开事务,B端插入一条记录

事务A端:

事务B端:

因为此时事务A的隔离级别设置为serializable,开始事务后,并没有提交,所以事务B只能等待。

事务A提交事务:

事务A端

事务B端

serializable完全锁定字段,若一个事务来查询同一份数据就必须等待,直到前一个事务完成并解除锁定为止是完整的隔离级别,会锁定对应的数据表格,因而会有效率的问题。



事务 数据 级别 隔离 客户 客户端 更新 查询 问题 一致 内容 实例 结论 范围 这是 实验 不同 事务所 数据库 现象 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 卫生院网络安全保密制度 爱云集网络技术有限公司怎么样 服务器中怎么用指令 网络安全法恶意ip ArcGIS数据库构建网络 炫彩互联网科技有限公司电话 淘宝客软件开发视频教程 freebsd服务器安全 中山市工业制造erp软件开发 毕业设计作品网站计算机网络技术 李晓东网络安全 临沧定制软件开发 商洛市网络安全部署会 专科软件开发专业怎么样 网络安全管理制度论文 怀化市开展网络安全宣传活动 法治进校园巡讲网络安全 第二届中国电信网络安全论坛 现代通信网络技术期末试卷 静安区上门软件开发代理品牌 铁路装车软件开发语言是什么 最高薪的软件开发语言 全球网络安全大学排名 软件开发师学习视频 惠普服务器测试指标 软考数据库工程师怎么复习 魔兽tbc服务器人数查询 西城区正规网络技术维修价格 建空间数据库的处理流程 数据库太大
0