Mysql底层原理十一:Mvcc

为什么要mvcc?

  • 提高并发度,如果读和写都是通过加锁的方式,并发肯定上不来,通过mvcc来实现写通过加锁,读通过mvcc readView机制
3.9.1 Undo版本链

image.png
再重复一遍,页面中的记录存放在用户表空间的数据页中,undo log存在系统表空间的undo segment中

3.9.2 ReadView
  • 内容有哪些

    • m_ids :表示生成生成ReadView时活跃的事务id列表
    • min_trx_id: 表示生成ReadView时活跃读写事务最小的id,也就是m_ids中的最小值
    • max_trx_id: 表示生成ReadView时系统分配给下一个事务的id值,
    • creator_trx_id: 表示生成该ReadView时事务id
  • 可见规则:

    • 大于max_trx_id,肯定不可见,说明我创建事务的时候,另外事务还没有创建
    • 小于 min_trx_id,肯定是可见的,说明我创建事务的时候,事务已经提交了
    • 小于max_trx_id,但是不在活跃列表中,肯定是可见的,说明更新在前查询在后,但是更新没有提交事务,所以刚开始活跃列表里有它,但是提交事务之后活跃列表就没有它了,所以更新提交完,再查一遍就能查到了
  • RC隔离级别:RC的时候需要在select的时候查询到别人提交的数据,所以RC的时候,是利用每次Select就去创建一次ReadView,保证能看到别人提交的数据

  • RR的级别:RR的时候第一个select的时候,就创建好ReadView,后续都使用的是这个ReadView,RR级别如果使用ReadView的话,没办法完全解决幻读,因为存在锁定读(不从readview里面拿数据,从数据库拿最新数据),还是会导致幻读

幻读的2种情况:

  1. Session A select * from t for update,然后 Session B insert into t, 再然后 Session A select * from t for update,就把Session B插入的数据查出来了
  2. 另外一种情况:

FireShot Capture 001 - MySQL 如何解决幻读(MVCC 原理分析) - 掘金 - juejin.cn.png

总结:

  • RR隔离级别下间隙锁才有效,RC 隔离级别没有间隙锁
  • RR隔离级别是为了解决幻读,快照读依靠mvcc控制,当前读通过间隙锁解决
  • 间隙锁和行锁合称 Next-Key Locks,每个 Next-key Locks是 [)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/598050.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RuoYi-Vue若依框架-在框架内用颜色选择器,页面显示色块

在用若依框架进行二次开发的时候写到自己的一个模块,其中涉及到颜色,我就想着是手动输入还是采用颜色选择器呢,考虑到后续涉及到另一个字段编码于时就采用了颜色选择器,选择完的颜色显示的是十六进制的颜色选择器,这时…

【Java网络编程】计算机网络基础概念

就目前而言,多数网络编程的系列的文章都在围绕着计算机网络体系进行阐述,但其中太多理论概念,对于大部分开发者而言,用途甚微。因此,在本系列中则会以实际开发者的工作为核心,从Java程序员的角度出发&#…

蓝桥-回文日期

目录 题目链接 ​编辑 ​编辑 什么是回文数?​编辑 代码 100%过 90%暴力 优化写的暴力代码 题目链接 2.回文日期 - 蓝桥云课 (lanqiao.cn) 什么是回文数? 代码 100%过 把那个90%的代码的循环限制条件去掉就行了,题目只是限制了N…

Peter算法小课堂—线性dp

今天,你读完这篇文章,普及组的动态规划已经可以秒了。 最长公共子序列 求两个数列的最长公共子序列(Longest Common Subsequence,LCS)的长度。 数列 X 和 Y 的最长公共子序列 Z,是指 Z 既是 X 的子序列&…

cutlass之基础类型

Coord Coord是一个基础数据类型&#xff0c;在cutlass用的很多&#xff0c;有必要掌握清楚&#xff0c;该类型主要使用场景如下&#xff1a; 顾名思义就是坐标保存。using stridecoord<2>使用方式, 保存一个tensor不同维度之间的步长&#xff0c;这样讲不太好理解步长&…

【JavaEE】_Spring MVC项目获取Cookie

目录 1. Cookie与Session基础知识 1.1 Cookie与Session的区别 2. 使用servlet原生方法获取Cookie 2.2 关于λ表达式遍历法的空指针问题 2.3 Cookie的伪造 3. 使用Spring注解获取Cookie 3.1 获取单个Cookie 3.2 获取多个Cookie 1. Cookie与Session基础知识 在本专栏HTT…

HTTP的介绍

一.什么是HTTP&#xff1f; Hyper Text Transfer Protocol,超文本传输协议&#xff0c;规定了浏览器和服务器之间数据传输的规则。 二.HTTP的特点 &#xff08;1&#xff09;基于TCP协议&#xff1a;面向连接&#xff0c;安全 &#xff08;2&#xff09;基于请求-响应模型的&…

学习周报:文献阅读+Fluent案例+水力学理论学习

目录 摘要 Abstract 文献阅读&#xff1a;物理信息的神经网络与湍流传质的非封闭机制模型相结合 文献摘要 提出问题 提出方案 实验设置 所需方程介绍 雷诺时均方程&#xff08;RANS&#xff09; K-epsilon两方程模型 神经网络框架 DNN部分 损失函数定义 PINN部分…

JDK、JRE和JDK的关系

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a;每天一个知识点 ✨特色专栏&#xff1a…

鱼骨图功能实现

dom: <div class="module-content"><div class="title"><span>[</span><p>鱼骨图</p><span>]</span></div><div class="line-mian"></div><div :ref="module + i&q…

配置vscode用于STM32编译,Debug

配置环境参考&#xff1a; Docs 用cubemx配置工程文件&#xff0c;用VScode打开工程文件。 编译的时候会有如下报错&#xff1a; vscode出现process_begin :CreateProcess failed 系统找不到指定文件 解决方案&#xff1a;在你的makefile中加上SHELLcmd.exe就可以了 参考…

VRRP+MSTP+BFD

一、组网 二、要求 PC6&#xff08;vlan 10内PC&#xff09;访问1.1.1.1走JR-1——CORE1——MSR到1.1.1.1 PC7&#xff08;vlan 20内PC&#xff09;访问1.1.1.1走JR-2——CORE2——MSR到1.1.1.1 链路故障时切换路线&#xff0c;来回路径一致 三、配置步骤 SR bfd echo-sou…