mysql中mvcc实现机制和原理

article/2025/9/15 11:56:55

目录

1.什么是mvcc?

2.mvcc中的快照读和当前读有什么区别和联系?

3.mvcc的作用是什么?

4.mvcc的实现机制和原理是什么?


1.什么是mvcc?

        mvcc全称是(Multi-Version Concurrency Control) 多版本并发控制,是数据库管理过程中的一种并发控制方式。数据库库中的并发控制一般是加锁。线程在操作共享资源时,需要加锁解决并发访问控制。锁又分为乐观锁和悲观锁。

      悲观锁:一上来,认为数据库会发生并发冲突,先锁住数据,不允许其他事物操作,直到本事务提交为止。

      乐观锁:在不锁定的情况下,更新数据,如果发现版本不一致,不更新数据,通过增加版本号比对来实现,还有cas等方式。

      mvcc本质是一种乐观锁的实现方式

2.mvcc中的快照读和当前读有什么区别和联系?

     mvcc有两种读的形式:快照读和当前读

     快照读:读写不冲突,每次读取到快照数据。例如 普通的select语句。

     当前读:每次读取到当前的最新数据。例如 select ...for update/select ... lock in share mode/delete /delete/insert

在不同的隔离级别下,快照读和当前读的读取到的数据可能不同

      在repeated-read隔离级别下,快照度可能读取的不是最新的数据,当前读读取的是最新的数据。

      在read committed隔离级别下,快照读和当前读读取的是最新的数据,快照度等价于当前读

3.mvcc的作用是什么?

        mysql默认的隔离级别是可重复读,快照读(select语句),使用mvcc解决了幻读的问题当前读(select ... for update) ,通过(next-key-lock)记录锁和间隙锁来解决幻读。

        mvcc在很大程度上避免了幻读,但是没有彻底的解决。有下面的两个场景没有解决幻读

案例1 对于快照读 事务A更新了事务B已经插入的记录,A事务两次查询结果记录条数不一致

user表数据

id

name

age

1

小张

11

2

小李

22

3

小王

33

4

小赵

44

id

事务A

事务B

1

begin

begin

2

select * from user where id=5

3

insert into users values(5,"小花",23)

commit;

4

update users set name="小明" where id=5

5

select * from user where id=5

       事务A的第1行和第5行的查询结果条数不一样,发生了幻读。

案例2 对于当前读 事务A先执行快照读,事务B插入了一条记录,事务A再执行当前读,导致两次查询结果记录数不同

还是上面的user数据集

id

事务A

事务B

1

begin

begin

2

select * from user where id>=1

3

insert into users values(5,"小花",23)

commit;

4

select * from user where id>=1 for update

       事务A的第1行和第4行的查询结果条数不一样,发生了幻读。

解决方案:事务开启后,先执行一次当前读 select for update,它会对当前事务加next-key-lock,避免其他事务插入记录。

4.mvcc的实现机制和原理是什么?

     mvcc是通过数据库的三个字段DB_TRX_ID(事务id),DB_ROLL_PTR(回滚指针),isDelete(是否删除的字段),undoLog(回滚日志)和read-view(读视图)来实现mvcc的可见性算法

     read-view是每个事务在进行一个select语句(快照读)时,产生一个read-view(读视图)有三个字段alive_trx_list,up_limit_id,low_limit_id,具体含义如下

    alive_trx_list:正在活跃的事务id列表

    up_limit_id:当前最小的事务id

    low_limit_id:当前最大事务id+1

    TRX_Id:当前记录的事务id

可见性算法分三种情况

     1. TRX_Id<up_limit_id|| TRX_Id==CUR_TRX_ID 可见,返回对应的记录

     2. TRX_Id>=low_limit_id 不可见 通过回滚指针找到上一条记录,继续判断,直到指针为空

     3. TRX_Id in alive_trx_list 不可见,事务未提交,通过回滚指针找到上一条记录,继续判断,指针指针为空,否则可见,返回对应的记录

     可见性算法执行流程图如下


http://chatgpt.dhexx.cn/article/VnGUhb3I.shtml

相关文章

MVCC的实现原理

什么是MVCC? MVCC MVCC&#xff0c;全称Multi-Version Concurrency Control&#xff0c;即多版本并发控制。MVCC是一种并发控制的方法&#xff0c;一般在数据库管理系统中&#xff0c;实现对数据库的并发访问&#xff0c;在编程语言中实现事务内存。 mvcc - 百度百科 MVCC在My…

mysql的MVCC机制详解

文章目录 1. 什么是MVCC机制&#xff1f;2. MVCC机制底层是怎么实现的2.1 undo日志版本链2.2 read view机制 3. undo版本链和read-view的对比规则4. 结合案例解释mvcc机制实现可重复读过程 1. 什么是MVCC机制&#xff1f; 首先来重新认识一下可重复读和串行化&#xff1a; 可…

认真学习MySQL中的MVCC机制

什么是MVCC&#xff1f;MVCC&#xff08;Multiversion Concurrency Control&#xff09;&#xff0c;多版本并发控制。顾名思义&#xff0c;MVCC是通过数据行的多个版本管理来实现数据库的并发控制。这项技术使得在InnoDB的事务隔离级别下执行一致性操作有了保证。换言之&#…

MVCC的含义,如何实现的?

欢迎大家关注我的公众号【老周聊架构】&#xff0c;Java后端主流技术栈的原理、源码分析、架构以及各种互联网高并发、高性能、高可用的解决方案。 一、MVCC简介 1、什么是MVCC MVCC(Multi Version Concurrency Control的简称)&#xff0c;代表多版本并发控制。与MVCC相对的&…

MySQL的MVCC机制

系列文章&#xff1a;关系型/非关系型【数据库】知识脉络 目录 MVCC翻译成中文是&#xff1f; MVCC(Multi-Version Concurrency Control) 回顾事务 MVCC是单打独斗吗&#xff1f; undo日志版本链 read view机制详解 MVCC机制是拿undo日志链和read-view对比 比对规则&…

什么是MVCC机制?

什么是MVCC机制&#xff1f; 什么是MVCC多版本并发控制机制 之前我们讲到&#xff0c;事务在并发环境下会带来脏读、脏写、不可重复读等诸多问题&#xff0c;为了解决这些问题&#xff0c;保证事务的ACID特性&#xff0c;出现了诸多隔离级别去解决这些问题&#xff0c;mysql默…

MySQL InnoDB的MVCC实现机制

MySQL InnoDB的MVCC实现机制 1.MVCC概述2.MVCC的实现原理隐式字段undo日志Read View(读视图)RR隔离级别的Read View方案 1.MVCC概述 什么是MVCC&#xff1f; MVCC&#xff0c;即多版本并发控制。MVCC是一种并发控制的方法&#xff0c;一般在数据库管理系统中&#xff0c;实现…

MVCC原理以及隔离机制

1、mysql是如何进行数据回滚的 mysql使用了大量的 undo日志、trx_id 字段以及 roll_pointer 字段来实现的数据回滚。版本链比对规则图&#xff1a; 查询 ​ 当mysql开启一个查询时 遇到的select语句会创建一个 read-view 一致性视图&#xff0c;这个视图里面保存 一个未提交…

【MVCC多版本并发控制】MVCC 机制的原理及实现,什么是MVCC,多版本并发控制

什么是 MVCC MVCC (Multiversion Concurrency Control) 中文全程叫多版本并发控制&#xff0c;是现代数据库&#xff08;包括 MySQL、Oracle、PostgreSQL 等&#xff09;引擎实现中常用的处理读写冲突的手段&#xff0c;目的在于提高数据库高并发场景下的吞吐性能。 如此一来…

MySql的MVCC实现机制

MVCC实现机制 快照读和当前读MVCC 快照读和当前读 在了解MySql的MVCC实现之前&#xff0c;需要先了解什么是快照读和当前读&#xff0c;以便于后续讲解 快照读&#xff1a;就是单纯的 SELECT 语句&#xff0c;不包括下面这两类语句: SELECT ... FOR UPDATE SELECT ... LOCK I…

MVCC机制略解

在mysql中&#xff0c;默认的隔离级别是可重复读。即在一个事物中读取到的数据总是一样的&#xff0c;即使其他事务把数据改了&#xff0c;那在这个事务中读取的数据还是第一次读取的数据。 mysql还可以设置为读已提交隔离级别。即一个事务中读取的数据&#xff0c;随着其他事务…

什么是MVCC,一文搞懂MySQL的MVCC机制

MVCC是什么 MVCC&#xff0c;即Multi-Version Concurrency Control &#xff08;多版本并发控制&#xff09;。它是一种并发控制的方法&#xff0c;一般在数据库管理系统中&#xff0c;实现对数据库的并发访问&#xff0c;在编程语言中实现事务内存。 数据库中同时存在多个版本…

对MVCC全面解析

简介 MVCC&#xff08;Multi-Version Concurrency Control&#xff09;即多版本并发控制。 MVCC的实现原理 我们在了解MVCC之前&#xff0c;首先先了解一下几个比较常见的锁。 读锁&#xff1a;也叫共享锁、S锁&#xff0c;若事务T对数据对象A加上S锁&#xff0c;则事务T可…

【MySQL】MVCC机制

什么是MVCC MVCC 英文全称&#xff1a;Multi-Version Concurrency Control&#xff0c;Mysql的事务隔离性就是主要靠MVCC机制来实现的。对一行数据的读和写默认是不会通过加锁互斥来保证隔离性的&#xff0c;这样避免了频繁的加锁互斥&#xff0c;而在串行化隔离级别为了保证较…

一文精通MVCC机制

MVCC(Multi-Version Concurrency Control)多版本并发控制机制 使用串行化隔离级别时&#xff0c;mysql会将所有的操作加锁互斥&#xff0c;来保证并发安全。这种方式必然降低并发性能。mysql在读已提交和可重复读隔离级别下&#xff0c;对一行数据的读和写两个操作默认是不会通…

数据库的MVCC机制

MVCC 1. 什么是MVCC MVCC &#xff08;Multiversion Concurrency Control&#xff09;&#xff0c;多版本并发控制。顾名思义&#xff0c;MVCC 是通过数据行的多个版 本管理来实现数据库的 并发控制 。这项技术使得在InnoDB的事务隔离级别下执行 一致性读 操作有了保 证。换言…

MySQL之MVCC机制

1. MVCC概念 MVCC&#xff0c;全称Multi-Version Concurrency Control&#xff0c;即多版本并发控制。MVCC是一种并发控制的方法&#xff0c;一般在数据库管理系统中&#xff0c;实现对数据库的并发访问&#xff0c;在编程语言中实现事务内存。 在Mysql的InnoDB引擎中就是指在…

【MySQL进阶-05】深入理解mvcc机制(详解)

MySql系列整体栏目 内容链接地址【一】深入理解mysql索引本质https://blog.csdn.net/zhenghuishengq/article/details/121027025【二】深入理解mysql索引优化以及explain关键字https://blog.csdn.net/zhenghuishengq/article/details/124552080【三】深入理解mysql的索引分类&a…

MVCC及实现原理

&#xff01;首先声明&#xff0c;MySQL 的测试环境是 5.7 前提概要 什么是 MVCC什么是当前读和快照读&#xff1f;当前读&#xff0c;快照读和 MVCC 的关系MVCC 实现原理 隐式字段undo日志Read View整体流程MVCC 相关问题 RR 是如何在 RC 级的基础上解决不可重复读的&#xf…

4gl程式debug常用技巧

1、带参数的D&#xff1a; ‘MISC’表示具体料号传入 2、指定行数设置断点 比如我要在程式axmt360中的211行开始D 进入Debug界面后按ctrlD 弹出界面 输入b 行数 点OK 出现上面表示已设置OK&#xff0c;然后点cancel或叉叉退出 最后点下面按扭&#xff0c;程式跑到210行时自…