【MySQL】可重复读隔离级别是否解决了幻读?

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 面试官:可重复读隔离级别是否解决了幻读了吗?不清楚是吧,没关系,那我们今天面试就先到这。

MySQL相关文章


并发问题

  • 脏读
  • 当前事务读到了其他事务保存但未提交的数据
  • 不可重复读
  • 当前事务读到了其他事务update的数据
  • 与脏读的区别是,不可重复读读到的是已提交的事务,脏读读到的是未提交的数据
  • 比如:开一个事务修改了某条数据,提交事务的时候发现这条数据已经被别的事务修改了
  • 幻读
  1. 当前事务读到了其他事务提交的insert、delete数据



隔离级别

  • 读未提交,会产生脏读、不可重复读、幻读
  • 读已提交,会产生不可重复读、幻读
  • 可重复度,会产生幻读
  • 串行化,不会发生并发问题


按照八股文里mysql隔离级别默认情况下为可重复读,可重复读隔离机制下避免了脏读,不可重复读,日常开发里却并没有出现过幻读,看似是MVCC多版本并发控制帮我们避开了幻读。


其实另有隐情,从一个小实验中就可以看出来,新建一个dept表存id和name字段。


image.png


分别进行下面两组事务操作:


image.png


开始两个表里都没有数据,右边事务里插入一条数据,显而易见因为mvcc特性左边的select数据一直不变。

image.png


左边事务虽然查不到,向表中插入id=29的数据会被锁住。

image.png


这是因为在select时会使用到mvcc机制的快照读,读取的是某个当前事务对应版本内的内容,但是在insert时会进行当前读,访问数据表中“最新”的数据,这时尽管右边的insert未提交,但当前读还是会读到,根据报错的信息,lock,得知在右边事务insert一行之后会进行加锁 (X锁),不允许其他事务修改,但能读取当前数据(当前读)即获取当前行的S锁,左边insert需要在右边事务释放锁之后才能进行insert/update操作(commit或者rollback)


那么尝试对其他id进行操作应该不会有问题吧

image.png

结果还是会被锁住,也就是说并不是只对id=99一条数据上了锁,仔细想想写锁可以限制住当前数据条数不被修改避免不可重复读,但依旧限制不了幻读。


mysql会对(-无穷大, 99) 和 (99, +无穷大)加锁,也就是所谓的间隙锁

  • X锁称为排他锁(悲观锁):对目标行添加当前事务的X锁,即可修改或删除操作
  • S锁称为共享锁(共享锁):对目标行添加当前事务的S锁,即可读当前行的数据
  • S锁是可以兼容的,即多个事务都可以持有对某行的读权限, 而X锁是不兼容的,即最多只有一个事务能获取当前行的修改或删除权限, 若其他事务需要获取X锁,必须等当前拥有X锁权限的事务释放X锁才能获取。
  • GAP锁成为间隙锁:当我们用范围条件检索数据而不是相等条件检索数据,并请求共享或排他锁时,InnoDB会给符合范围条件的已有数据记录的索引项加锁对于键值在条件范围内但并不存在 的记录,叫做“间隙(GAP)”。



总结

可重复度隔离级别下还是会存在幻读问题,mysql通过使用the-next锁避免出现幻读(行锁+gap锁)。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
Oracle 关系型数据库 MySQL
MySQL相关(六)- 事务隔离级别的实现方案(MVCC)
MySQL相关(六)- 事务隔离级别的实现方案(MVCC)
66 0
|
4月前
|
存储 SQL 关系型数据库
MySQL相关(五)- 事务四大特性及隔离级别的详细介绍
MySQL相关(五)- 事务四大特性及隔离级别的详细介绍
57 0
|
4月前
|
NoSQL 关系型数据库 MySQL
MySQL - 深入理解 MySQL 的事务和隔离级别
MySQL - 深入理解 MySQL 的事务和隔离级别
452 0
|
1月前
|
人工智能 小程序 关系型数据库
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
本文以热门游戏《黑神话:悟空》为契机,深入浅出地解析了数据库事务的四种隔离级别:读未提交、读已提交、可重复读和串行化。通过具体示例,展示了不同隔离级别下的事务行为差异及可能遇到的问题,如脏读、不可重复读和幻读等。此外,还介绍了在MySQL中设置隔离级别的方法,包括全局和会话级别的调整,并通过实操演示了各隔离级别下的具体效果。本文旨在帮助开发者更好地理解和运用事务隔离级别,以提升数据库应用的一致性和性能。
114 2
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
|
1月前
|
算法 关系型数据库 MySQL
一天五道Java面试题----第七天(mysql索引结构,各自的优劣--------->事务的基本特性和隔离级别)
这篇文章是关于MySQL的面试题总结,包括索引结构的优劣、索引设计原则、MySQL锁的类型、执行计划的解读以及事务的基本特性和隔离级别。
|
2月前
|
SQL 关系型数据库 MySQL
(七)MySQL事务篇:ACID原则、事务隔离级别及事务机制原理剖析
众所周知,MySQL数据库的核心功能就是存储数据,通常是整个业务系统中最重要的一层,可谓是整个系统的“大本营”,因此只要MySQL存在些许隐患问题,对于整个系统而言都是致命的。
|
2月前
|
关系型数据库 MySQL
面试题MySQL问题之Read uncommitted隔离级别不适用MVCC如何解决
面试题MySQL问题之Read uncommitted隔离级别不适用MVCC如何解决
37 1
|
2月前
|
存储 SQL 关系型数据库
Mysql的四种隔离级别
Mysql的四种隔离级别
|
4月前
|
SQL 关系型数据库 MySQL
Mysql事务隔离级别和锁特性
Mysql事务隔离级别和锁特性
|
3月前
|
关系型数据库 MySQL
mysql事务隔离级别MVCC
mysql事务隔离级别MVCC