MySQL隔离级别与MySQL的锁

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL隔离级别与MySQL的锁

MySQL隔离级别


1.png


测试隔离级别


数据库准备


数据库如下图所示,所有字段都是int(方便测试),id为主键索引,name为普通索引(唯一索引),age没有索引


2.png


Read Uncommitted(读取未提交内容)


打开两个mysql终端,都设置session级别的隔离级别为读取未提交内容(本次会话有效)


set session transaction isolation level read uncommitted;


如下表所示,

事务B在第4步进行了修改(还没有提交或者回滚),

事务A在第5步就已经可以读取到修改(未提交或者回滚)的内容,出现了(脏读)

事务B在第6步回滚了, 撤销了修改操作,那么第5步读的就不正确了


微信截图_20230224150908.png


Read Committed(读取提交内容)


打开两个mysql终端,都设置session级别的隔离级别为读取提交内容(本次会话有效)


set session transaction isolation level read committed;


如下表所示,

事务B在步骤4修改了数据

事务A在步骤5读取数据,(解决了脏读问题)

事务B在步骤6提交了修改内容

事务A在步骤7读取的数据和步骤5读取的数据不一样(出现了不可重复读问题)


3.png


Repeatable Read(可重读)


打开两个mysql终端,都设置session级别的隔离级别为可重读(本次会话有效)


set session transaction isolation level  repeatable read;


下面的例子有点不恰当,下面的例子有点不恰当,下面的例子有点不恰当


如下表所示,

事务A在步骤3和步骤6读取的数据一样(解决了不可重复度)

事务B在步骤4插入主键为4的数据

事务A在步骤7插入主键为4的数据报错 (出现了幻读)


4.png


Serializable(可串行化)


打开两个mysql终端,都设置session级别的隔离级别为串行化(本次会话有效)


set session transaction isolation level  serializable;


如下表所示,


事务B在步骤5遇到了阻塞,性能差


5.png


MySQL的锁


innodb行锁,锁的是什么?


答:锁的是索引。有索引时锁索引,没有索引的时候锁表。

如下表所示,id有主键索引,name有唯一索引,age无索引


6.png


7.png


乐观锁和悲观锁


乐观锁


乐观锁与数据库无关


如下表所示,有一个字段是verison 版本号


###伪代码,无竞争逻辑
student = select * from student where id = 1;
currentVersion = student.version
update student set age = 11 , version = version + 1 where id = 1 and  version = currentVersion ;
###伪代码,有竞争逻辑
student = select * from student where id = 1;
currentVersion = student.version
//此时中间有另一个客户端又修改了这条记录,version+1了
update student set age = 11 , version = version + 1 where id = 1 and  version = currentVersion ;//这条修改失败,因为currentVersion已经过时,不存在


8.png


悲观锁


说到这里,由悲观锁涉及到的另外两个锁概念就出来了,它们就是共享锁与排它锁。共享锁和排它锁是悲观锁的不同的实现,它俩都属于悲观锁的范畴。


共享锁和排它锁


共享锁


select * from student WHERE id = 1 lock in share mode;


9..png


排它锁


增、删、改默认添加的是排它锁。


select * from student WHERE id = 1 for update;


给一条记录上了排它锁后,其他事务不能给改条记录上共享锁和排它锁。


意向锁


意向锁是表级别锁,意向锁不是人为的,是数据库自动的。


以意向排它锁为例,当事务A给记录1上锁时,先获取表的意向排它锁,然后在给记录1上锁;此时事务B给表上表锁,先获取表的意向排它锁,然后在锁表,但是此时意向排它锁在被事务A获取,所示事务B锁表失败。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
12天前
|
人工智能 小程序 关系型数据库
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
本文以热门游戏《黑神话:悟空》为契机,深入浅出地解析了数据库事务的四种隔离级别:读未提交、读已提交、可重复读和串行化。通过具体示例,展示了不同隔离级别下的事务行为差异及可能遇到的问题,如脏读、不可重复读和幻读等。此外,还介绍了在MySQL中设置隔离级别的方法,包括全局和会话级别的调整,并通过实操演示了各隔离级别下的具体效果。本文旨在帮助开发者更好地理解和运用事务隔离级别,以提升数据库应用的一致性和性能。
78 2
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
|
15天前
|
监控 关系型数据库 MySQL
在Linux中,mysql的innodb如何定位锁问题?
在Linux中,mysql的innodb如何定位锁问题?
|
22天前
|
存储 SQL 关系型数据库
深入MySQL锁机制:原理、死锁解决及Java防范技巧
深入MySQL锁机制:原理、死锁解决及Java防范技巧
|
22天前
|
存储 SQL 关系型数据库
深入解析MySQL事务机制和锁机制
深入解析MySQL事务机制和锁机制
|
28天前
|
SQL 存储 关系型数据库
"MySQL增列必锁表?揭秘InnoDB在线DDL,让你的数据库操作飞一般,性能无忧!"
【8月更文挑战第11天】在数据库领域,MySQL凭借其稳定高效的表现深受开发者喜爱。对于是否会在给数据表添加列时锁表的问题,MySQL的行为受版本、存储引擎等因素影响。从5.6版起,InnoDB支持在线DDL,可在改动表结构时保持表的可访问性,避免长时间锁表。而MyISAM等则需锁表完成操作。例如,在使用InnoDB的表上运行`ALTER TABLE users ADD COLUMN email VARCHAR(255);`时,通常不会完全锁表。虽然在线DDL提高了灵活性,但复杂操作或大表变更仍可能暂时影响性能。因此,进行结构变更前应评估其影响并择机执行。
42 6
|
24天前
|
算法 关系型数据库 MySQL
一天五道Java面试题----第七天(mysql索引结构,各自的优劣--------->事务的基本特性和隔离级别)
这篇文章是关于MySQL的面试题总结,包括索引结构的优劣、索引设计原则、MySQL锁的类型、执行计划的解读以及事务的基本特性和隔离级别。
|
26天前
|
存储 SQL 关系型数据库
MySQL中的update操作与锁机制
本文探讨MySQL中`UPDATE`操作的自动加锁机制及其对数据一致性的保障作用。尤其在InnoDB存储引擎下,系统会在涉及索引的更新操作中加行锁或间隙锁,防止多事务并发修改同一条记录。通过福利码兑换系统的实例展示,当线程A开启事务更新库存时,线程B试图更新相同记录会被阻塞,直至线程A提交。此外,文章还介绍了乐观锁及版本号控制等策略进一步提升并发性能的方法。作者:小明爱吃火锅,来源:稀土掘金。
|
14天前
|
关系型数据库 MySQL 数据库
MySQL MVCC和间隙锁有什么区别?
【8月更文挑战第24天】MySQL MVCC和间隙锁有什么区别?
30 0
|
17天前
|
存储 关系型数据库 MySQL
mysql锁的知识点简述
了解和合理应用MySQL中的锁机制,对于设计高并发、高可用的数据库应用至关重要。在系统设计初期就要考量锁策略,根据实际使用场景灵活调整,以最小化锁竞争,提高事务处理速度。
35 0
|
2月前
|
SQL 算法 关系型数据库
(十)全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
经过《MySQL锁机制》、《MySQL-MVCC机制》两篇后,咱们已经大致了解MySQL中处理并发事务的手段,不过对于锁机制、MVCC机制都并未与之前说到的《MySQL事务机制》产生关联关系,同时对于MySQL锁机制的实现原理也未曾剖析,因此本篇作为事务、锁、MVCC这三者的汇总篇,会在本章中补全之前空缺的一些细节,同时也会将锁、MVCC机制与事务机制之间的关系彻底理清楚。

热门文章

最新文章

下一篇
DDNS