mysql mvcc 隔离级别(详解MySQL事务的隔离级别与MVCC)
类别:数据库 浏览量:1617
时间:2021-10-13 00:30:20 mysql mvcc 隔离级别
详解MySQL事务的隔离级别与MVCC事务隔离级别
事务并发执行遇到的问题
-
脏写
- 如果一个事务修改了另一个未提交事务修改过的数据,那就意味着发生了脏写
-
脏读
- 如果一个事务读到了另一个未提交事务修改过的数据,那就意味着发生了脏读
-
不可重复读
- 如果一个事务只能读到另一个已经提交的事务修改过的数据,并且其他事务每对该数据进行一次修改并提交后,该事务都能查询到最新值,那就意味着发生了不可重复读
-
幻读
- 如果一个事务先根据某些条件查询出一些记录,之后另一个事务又向表中插入了符合这些条件的记录,原先的事务再次按照该条件查询时,能把另一个事务插入的记录也读出来,那就意味着发生了幻读。
- 幻读强调的是一个事务按照某个相同条件多次读取记录时,后读取时读到了之前没有读到的记录
- 那对于先前已经读到的记录,之后又读取不到这种情况,算啥呢?其实这相当于对每一条记录都发生了不可重复读的现象。幻读只是重点强调了读取到了之前读取没有获取到的记录。
sql标准中的四种隔离级别
- read uncommitted: 未提交读 脏读、不可重复读、幻读 发生
- read committed:已提交读 不可重复读、幻读 发生
- repeatble read:可重复读 幻读 发生
- serializable:可串行化 不发生
mysql中支持的四种隔离级别
- mysql在repeatable read隔离级别下,是可以禁止幻读问题的发生的(关于如何禁止我们之后会详细说明的)
- mysql默认隔离级别为repeatable read
mvcc原理
版本链
对于使用innodb存储引擎的表来说,它的聚簇索引记录中都包含两个必要的隐藏列
- trx_id:每次一个事务对某条聚簇索引记录进行改动时,都会把该事务的事务id赋值给trx_id隐藏列
- roll_pointer:每次对某条聚簇索引记录进行改动时,都会把旧的版本写入到undo日志,然后这个隐藏列就相当于一个指针,可以通过它来找到该记录修改前的信息。
readview
- 对于使用read uncimmitted隔离级别的事务来说,由于可以读到未提交事务修改过的记录,所以直接读取记录的最新版本就好了;
- 对于使用read committed 和repeatable read 隔离级别的事务来说,都必须保证读到已经提交了的事务修改过的记录,也就是说假如另一个事务已经修改了记录但是尚未提交,是不能直接读取到最新版本记录的。核心问题:需要判断一下版本链中的哪个版本是当前事务可见的。为此设计了readview
-
readview包含4个比较重要的内容:
- m_ids:表示在生成readview时当前系统中活跃的读写事务的事务id
- min_trx_id:表示生成readview时当前系统中活跃的读写事务中最小的事务id,也就是m_ids中的最小值
- max_trx_id: 表示生成readview时系统中应该分配给下一个事务的id值
-
creator_trx_id:表示生成该readview的事务的事务id
- 我们前边说过,只有在对表中的记录做改动时(执行insert、delete、update这些语句时)才会为事务分配事务id,否则在一个只读事务中的事务id值都默认为0。
-
有了这个readview,这样在访问某条记录时,只需要按照下边的步骤判断记录的某个版本是否可见:
- 如果被访问的版本的trx_id属性与readview中的creator_trx_id相同,意味着当前事务在访问它自己修改过的记录,所以该版本可以被当前事务访问
- 如果被访问的trx_id属性值小于readview中的min_trx_id值,表明生成该版本的事务在当前事务生成readview时已经提交,所以该版本可以被当前事务访问
- 如果被访问版本的trx_id属性值大于或等于readview中的max_trx_id值,表明生成该版本的事务在当前事务生成readview后才开启,所以该版本不可以被当前事务访问
- 如果被访问版本的trx_id属性值在readview的min_trx_id和max_trx_id之间,那就需要判断一下trx_id属性值是不是在m_ids列表中,如果在,说明创建readview时生成该版本的事务还是活跃的,该版本不可被访问;如果不在,说明创建readview时生成该版本的事务已经被提交,该版本可以被访问。
总结一下:
- read committed隔离级别的事务在每次查询开始时都会生成一个独立的readview
- repeatable read :在第一次读取数据时生成一个readview,也就是说两次select 查询得到的结果是重复的。
mvcc总结: 所谓的mvcc指的就是在使用 read committed 和repeatable read 这两种隔离级别的事务在执行普通的select 操作时访问的记录的版本链的过程,这样子可以使不用的事务的读-写、写-读操作并发执行,从而提升性能。
mysql如何在rr级别解决幻读的
1.当前读,读的是最新版本,并且需要获取对应记录的锁,如下sql
- select ... lock in share mode
- select ... for update
- update 、delete 、insert
是通过next-key 来实现幻读的
2.快照读 是通过mvcc 来解决的
以上就是详解mysql事务的隔离级别与mvcc的详细内容,更多关于mysql事务的隔离级别与mvcc的资料请关注开心学习网其它相关文章!
原文链接:https://juejin.cn/post/6953513035394711582
您可能感兴趣
- mysql关联查询详解(详解mysql 组合查询)
- mysql慢日志查询作用(MySQL 慢查询日志的开启与配置)
- mysql中group_concat
- mysql如何解决主从延迟(MySQL主从延迟问题解决)
- mysql大量数据怎么处理(MySQL删除和插入数据很慢的问题解决)
- mysql里修改密码命令(MySQL修改账号密码方法大全小结)
- mysql的字符串截取函数(MySQL实现字符串的拼接,截取,替换,查找位置的操作)
- mysql索引失效怎么办(MySQL选错索引的原因以及解决方案)
- mysql8.0.16安装步骤图解(mysql 8.0.22 安装配置图文教程)
- mysql整体架构设计(MySQL 整体架构介绍)
- dockerfile构建mysql镜像并初始化(docker-compose基于MySQL8部署项目的实现)
- linuxmysql怎么设置root密码(Linux mysql-5.6如何实现重置root密码)
- mysql自增长语句(mysql实现自增序列的示例代码)
- 通过接口访问mysql数据库(使用mysql记录从url返回的http GET请求数据操作)
- docker安装mysql后无法连接(Docker 安装 MySQL 并实现远程连接教程)
- mysql的连接代码(MySQL 连接查询的原理和应用)
- Google 推出了一个游戏生成器,让不会编程的你也能自己设计游戏(推出了一个游戏生成器)
- 二胎家庭老大爱闹情绪,用这招很有效(二胎家庭老大爱闹情绪)
- 一个30岁男人外遇失败的全过程(一个30岁男人外遇失败的全过程)
- 《无敌破坏王2》 不聊彩蛋,聊聊我从动画里看到的现实那些事儿(无敌破坏王2不聊彩蛋)
- 《寄生虫》 三观不正 人类悲欢从来不相通,感同身受也并非本能(寄生虫三观不正)
- 这部动漫中的女孩子,可比101女孩更加励志(这部动漫中的女孩子)
热门推荐
- css怎样设置文字不换行(css是如何实现在页面文字不换行、自动换行、强制换行的方法)
- mysql高级概念(MySQL 自定义变量的概念及特点)
- tomcat架构结构图(Tomcat核心组件及应用架构详解)
- vue怎么注册公共组件(解读Vue组件注册方式)
- dede联动菜单样式(dede标签云如何生成不同颜色、不同大小的tag标签)
- python蓝牙knn算法(python使用KNN算法识别手写数字)
- iis服务器无法启动(Windows服务器中IIS返回的网页错误代码大汇总及原因解)
- vmware虚拟机与本机共享(vmware16虚拟机如何设置共享本机的文件夹)
- sql server 2012 错误5123(SQL SERVER 9003错误解决方法)
- 查看docker image版本(解决docker images 镜像消失的问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9