MySQL数据库MVCC机制底层原理详解

mvcc机制即多版本并发控制

当在事务中使用了写操作(增删改)语句时会给当前事务生成一个事务id,事务id是递增的

同时,对于被修改的行的数据会创建一个数据版本 ,这个数据版本除了包含原有的字段还会包含一个事务id和一个回滚指针

接下来通过几条sql语句来讲解mvcc机制:

首先假设这里有一个account表,此时里面只有一条数据

 

trx_id:事务id

roll_pointer:回滚指针 

假设上面的4个事务都已经开启了,现在执行3行和4行,由于是写操作,所以会生成一个事务id,这里我们假设是110 和 120,注意此处操作的不是account表,只是为了生成事务id。

接下来执行第5行,同样是一个写操作也会生成事务id,同时上面我们说过,对于被修改的数据行还会生成一个数据版本,于是这个新生成的数据版本就是当前数据行最新的版本,它的回滚指针会指向上一个版本:

紧接着事务130就提交了,然后另一个事务指向了一个查询语句,这里大家应该都知道结果是ting130,因为事务130提交了。注意查询语句不会生成事务id

此时继续往下执行,8和9行,同样是更新语句所以也会生成数据版本,注意每个事务中只有第一次执行写操作语句时会生成事务id。

此时第10行执行一个查询语句,我们分析一下此时的查询结果是什么:

当事务中第一次执行查询操作时,会生成一致性视图 read -view,也可以称为快照,他由当前未提交事务id组成的数组和已创建的最大事务id(max_id)组成,其中未提交事务id中最小的id我们称为min_id,通过min_id和max_id可以把事务分为三个部分:

由于min_id是所有未提交事务中最小的id,所以事务id小于min_id的一定是已经提交的事务是可见的,同时大于max_id的事务,是生成快照时还没有创建的事务,是不可见的,在min_id和max_id之间的事务要分两种情况,在未提交数组中则说明是不可见的,不在则说明事务已经提交是可见的,当执行查询语句,就会沿着版本链从最新的数据开始查,直到查到可见的数据。

所以第7行时,第四个事务就已经生成了快照,当时只有事务130提交了,所以生成的read_view是:[ 110 , 120 ] 130 ,110即为min_id,130为max_id,由于同一个事务中只有第一次使用查询语句时会生成read_view,所以此时第10行的查询语句会沿用上次的read_view即 [ 110 , 120 ] 130

此时我们沿着版本链去查数据,首先查到的是ting112,发现事务id在未提交事务数组中说明不可见,沿着回滚指针往下找到ting111发现同样不可见,继续往下找到ting130,事务id为130 ,130 小于等于max_id并且不在未提交事务数组中,是可见的,于是返回ting130。

接下来继续往下执行,到第14行的时候,又将执行一条查询语句,可以先不看下面自己试着梳理一下返回什么。

此时版本链中又多了两条数据:

我们同样按照read_view在版本链中找,注意,这里不会生成新的read_view会沿用上次生成的

[ 110 , 120 ] 130

首先找到ting122,ting121发现事务id为120不可见,继续往下找到ting112,ting111 事务id为110同样不可见,在往下找到ting130事务id为130是可见的,所以返回ting130

再做个练习:

此时第14行的查询语句会返回什么? 

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

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

相关文章

Linux驱动开发—创建总线,创建属性文件

文章目录 1.什么是BUS?1.1总线的主要概念1.2总线的操作1.3总线的实现 2.创建总线关键结构体解析2.1注册总线到系统2.2 struct bus_type *bus 解析 3.实验结果分析1. devices 目录2. drivers 目录3. drivers_autoprobe 文件4. drivers_probe 文件5. uevent 文件 4.在…

【Rust光年纪】深度解读:Rust语言中各类消息队列客户端库详细对比

选择最佳 Rust 消息队列客户端库:全面对比与分析 前言 随着现代应用程序的复杂性不断增加,消息队列成为构建可靠、高性能系统的重要组件。本文将介绍一些用于Rust语言的消息队列客户端库,包括AMQP、Apache Kafka、NSQ、Apache Pulsar和Rock…

开发新系统时,数据库字符集怎么选择对中文的支持最好?

在新开发的系统时,如果你希望确保中文按拼音顺序正确排序,同时支持更多的特殊字符与符号,下面是对 utf8mb4_zh_cn_ci、utf8mb4_unicode_ci 和 utf8mb4_unicode_520_ci 这几种字符集和校对规则的分析以及推荐方案: 校对规则分析 utf8mb4_zh_cn_ci: 特点:这是专为简体中文…

goalng http client的MaxIdleConnsPerHost,MaxIdleConns,MaxConnsPerHost参数设置总结

MaxIdleConnsPerHost:优先设置这个,决定了对于单个Host需要维持的连接池大小。该值的合理确定,应该根据性能测试的结果调整。MaxIdleConns:客户端连接单个Host,不少于MaxIdleConnsPerHost大小,不然影响MaxI…

数据压缩(2)——变长编码

【定长编码】 变长和定长是很基本的概念,不光是在数据压缩,在其他很多地方都可以见到,这里就不多说了。 前文说过,在数据压缩时,我们需要用某些字符A替换或修改某些字符B,字符A占用的存储空间更小一些。 …

【力扣】划分为k个相等的子集

🔥博客主页: 我要成为C领域大神🎥系列专栏:【C核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 给定一个整数数组 …

超越基础:Visual Basic在科学计算与数据分析的革新应用

标题:超越基础:Visual Basic在科学计算与数据分析的革新应用 Visual Basic(VB),最初以其易于学习和使用而闻名,常被视为入门级编程语言。然而,VB的潜力远不止于简单的应用程序开发。在科学计算…

WHAT - 综合书单推荐

拥有一个成功的人生,书籍确实是一个重要的知识来源。可以将书籍分为几个主要类别,每个类别对应不同的知识领域和成长方向。以下是一些建议的分类及每类书籍推荐: 1. 个人发展与心理学 《如何赢得朋友与影响他人》 - 戴尔卡耐基《思考&#…

【qt】锁

线程安全问题. 多线程程序太复杂了. 加锁 把多个线程要访问的公共资源,通过锁保护起来.>把并发执行变成串行执行. Linux mutex 互斥量. C11引入std::mutex Qt 同样也提供了对应的锁,来针对系统提供的锁进行封装.QMutex 多个线程进行加锁的对象&…

example-apisix-1 清空日志之后启动异常处理

异常信息 2024/08/27 11:34:33 [emerg] 1#1: bind() to unix:/usr/local/apisix/conf/config_listen.sock failed (98: Address already in use) nginx: [emerg] bind() to unix:/usr/local/apisix/conf/config_listen.sock failed (98: Address already in use) 2024/08/27 1…

【生日视频制作】室内告白表白祝福布置霓虹灯AE模板修改文字软件生成器教程特效素材【AE模板】

室内告白表白祝福布置霓虹灯生日视频制作教程AE模板改字生成器 怎么如何做的【生日视频制作】室内告白表白祝福布置霓虹灯AE模板修改文字软件生成器教程特效素材【AE模板】 生日视频制作步骤: 安装AE软件下载AE模板把AE模板导入AE软件修改图片或文字渲染出视频

【Go - 每日一小问: 对未初始化的的 chan 进行读写,会怎么样?为什么?】

对未初始化的 chan 进行读写会有不同的行为: 1. 对未初始化的 chan 进行读取 读取操作: 对未初始化的 chan 进行读取操作会导致永久阻塞(deadlock),因为没有任何 goroutine 可以向这个 chan 发送数据。读取操作会一直…

Signac R|如何合并多个 Seurat 对象 (1)

引言 在本文中演示了如何合并包含单细胞染色质数据的多个 Seurat 对象。为了进行演示,将使用 10x Genomics 提供的四个 scATAC-seq PBMC 数据集: 500-cell PBMC 1k-cell PBMC 5k-cell PBMC 10k-cell PBMC 实战 在整合多个单细胞染色质数据集的过程中&…

SAP与生产制造MPM系统集成案例

一、需求介绍 某公司为保证企业内部生产管理系统的多项基础数据的同步更新,确保各模块间信息的一致性和准确性,对后续的生产计划和物料管理打下基础,该公司将MPM系统和SAP系统经过SAP PO中间件集成平台进行了集成。MPM全称为Manufacturing…

超实用的8个无版权、免费、高清图片素材网站整理

不管是设计、文章配图,还是视频制作,图片都至关重要。但是图片版权一直都是困扰很多设计、自媒体以及企业的大问题。现在,因为图片侵权被告的案例已经是司空见惯了,有的公众号甚至因为图片版权问题遭受致命打击。 1. Pexels Pexe…

Spring Boot 全局异常@ControllerAdvice和@RestControllerAdvice的区别

在Spring Boot中,ControllerAdvice和RestControllerAdvice都可以用于实现全局异常处理,但它们在处理方式和返回值类型上略有不同。至于为什么在某些情况下可能更偏向于使用RestControllerAdvice而不是ControllerAdvice,这主要取决于你的应用类…

前后端传参@RequestParam使用上的一个小坑

RequestParam(value "art") String art 默认情况下,value "art"表示前端传入参数的名字叫art,如果前端不传的话会报错 RequestParam(value "art" required false) String art 当equired false 时表示前端可以不传这个…

Spring框架:开发者的得力伙伴,魅力何在?

目录 一. Spring介绍 二. Spring搭建 三. Spring Bean管理 ▐ 管理方式 ▐ 依赖注入 四. Spring数据访问层管理 五. Spring集成MyBatis 海漫浩浩,我亦苦作舟!大家一起学习,一起进步! 一. Spring介绍 Spring是什么? Spring 是一个轻量级的, IOC 和 AOP 的一站式 J…

2024年最新Java面试宝典系列-Collections集合篇1

Java中的集合类有哪些?它们的特点是什么 List:有序集合,允许重复元素,实现类如ArrayList、LinkedList。Set:无序集合,不允许重复元素,实现类如HashSet、TreeSet。Map:键值对集合&am…

阿里云服务器 篇七:服务器热备份/定时备份

文章目录 系列文章bypy其他备选项目安装bypy使用bypy命令帮助绑定百度账号查看网盘空间大小和账号信息显示在百度网盘中的根目录在百度网盘中创建备份目录百度网盘中的其他文件操作命令从本地目录同步到百度网盘中在云服务器设置定时同步创建云端备份目录为sudo命令做准备创建同…