MySQL的MVCC是什么

文章目录

      • MVCC是什么
      • MVCC的作用
      • MVCC的实现原理
      • Read View是什么
      • Read View如何判断某个版本可以访问

MVCC是什么

MVCC(Multiversion concurrency control)是同一行数据保留多版本的一种方式,进而实现并发控制。
在查询时,通过read view版本链找到对应版本的数据。

MVCC的作用

提升并发性能。对于高并发场景,MVCC比行级锁开销更小

MVCC的实现原理

MVCC的实现依赖于版本链,版本链通过表的三个隐藏字段实现:

  1. DB_TRX_ID:当前事务id(唯一)
  2. DB_ROLL_PRT:回滚指针,指向当前行记录的上一个版本
  3. DB_ROW_ID:主键,如果数据表没有主键,InnoDB会自动生成主键

表的某一行记录示例
在这里插入图片描述

它表示id=1,name=张三,age=19的这条行记录是由事务id=10的事务创建/修改

Read View是什么

read view可以理解为将数据在每个时刻的状态拍成“照片”记录下来。当需要获取时刻t的数据时,就从t时间拍的”照片“上获取数据。
Read View结构:
在这里插入图片描述

Read View如何判断某个版本可以访问

在这里插入图片描述

  1. trx_id == creator_trx_id修改这条行记录的事务如果和创建Read View(也就是查询这条行记录)的事务是同一个事务,那么就可以访问这个版本的行记录数据。
  2. trx_id < min_trx_id:行记录的事务id未提交的最小事务id还要小。说明修改该行记录的事务已经提交。该版本的事务可以被当前事务读取到。
  3. trx_id > max_trx_id:说明当前版本的事务是在生成Read View之后才产生,当前事务无法访问。
  4. min_trx_id <= trx_id <= max_trx_id
    1. 如果在m_ids中存在trx_id,说明是未提交的事务,不可访问
    2. 不存在,说明trx_id已经提交了,可以访问。

例如:
有如下两个事务
在这里插入图片描述
事务id=20的事务将id=1的行记录的name先改成李四,然后改成王五。
事务id=60的事务对其他表进行一些操作。
在这里插入图片描述

此时进行查询select * from users where id = 1,生成的Read View如下图:
在这里插入图片描述 此时未提交的事务有2060,所以m_ids为[20,60]
生成该Read View的是查询语句,所以creator_trx_id=0(一个事务只有对数据库的数据进行修改操作(增,删,改)的时候,才会为事务分配一个唯一事务id,查询操作的事务没有进行对数据进行修改操作,所以trx_id就是默认的0)

将行记录的每个版本的trx_id与时间轴对比,判断此版本是否可以访问
在这里插入图片描述

此时查询能查询到的数据应该是name=“张三”,原因如下表:

nametrx_id == creator_trx_idtrx_id < min_trx_idtrx_id > max_trx_idmin_trx_id <= trx_id <= max_trx_id结果
王五符合,但在m_ids中无法访问
李四同上无法访问
张三符合可以访问

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

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

相关文章

go中make、new和直接var的区别

文章目录直接varmakenew小结直接var func main(){var sli []intfmt.Println(sli) // 打印结果为&#xff1a;[]fmt.Println(len(sli)) // 打印结果为&#xff1a;0fmt.Println(cap(sli)) // 打印结果为&#xff1a;0fmt.Println(sli[0]) // panic: index out of…

论述类文本知识框架_高考语文“论述类文本阅读”:三步走,拿满分

【原创首发】新的学期开始了。高三的定位考试也结束了。成绩下来了&#xff0c;有的同学拿着卷子找着我&#xff1a;“老师&#xff0c;你看看&#xff0c;我第一道大题三道错了两道&#xff0c;咋办呀&#xff1f;”高考语文试卷的第一大道试题”论述类文本阅读“这道题&#…

mysql数据自定义随机_Mysql 自定义随机字符串

前几天在开发一个系统&#xff0c;需要用到随机字符串&#xff0c;但是mysql的库函数有没有直接提供&#xff0c;就简单的利用现有的函数东拼西凑出随机字符串来.下面简单的说下实现当时.1.简单粗暴.select ..., substring(MD5(RAND()),floor(RAND()*26)1,6) as rand_str .....…

php连接mysql乱码原因_PHP连接MYSQL出现乱码的原因与解决办法

PHP连接mysql出现乱码的原因与解决方法解决MySql数据库乱码的一个首要前提是保证 数据库数据表前端显示 编码一致&#xff0c;国内项目一般统一设定为GB2312或GBK&#xff0c;而国际化项目则一般使用utf8。另外&#xff0c;字符集设定完毕之后记得重启目标机MySql服务。PHP连接…

linux查看非注释行_Linux筛除空行和注释行的技巧

CentOS7.3学习笔记总结(四十一)- Linux筛除空行和注释行的技巧 在linux系统中的很多文件,写程序的人为了方便查阅整篇文档,写了很多注释,加了很多空行,虽然方便了整体的阅读,但是参数的添加、删除、修改等就没有那么友好了,我们就需要利用命令行筛选出没有这些内容的内容…

mysql数据迁移双写_数据迁移类测试策略

二、迁移类测试策略1、概述随着业务需求或数据量增长到一定程度&#xff0c;往往需要进行数据库切换&#xff0c;这里就伴随这数据迁移。关键字&#xff1a; 全量数据迁移&#xff0c;增量数据迁移&#xff0c;分库分表&#xff0c;数据双写&#xff0c;oracle、mysql、hbase……

where is null mysql_SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法

SET SQL SELECT * FROM Comment with(nolock) WHERE 11And (ProjectIds Is Null or ProjectId ProjectIds)And (Scores is null or Score Scores)印象中记得&#xff0c;以前在做Oracle开发时&#xff0c;这种写法是会导致全表扫描的&#xff0c;用不上索引&#xff0c;不知道…

lambda的java_一分钟搞明白java8中的lambda

项目结构是这样的User是一个普通的pojo类UserCompare是一个实现了Comprator的类现在我们有一个需求&#xff1a;给一个user组成的list 按照user的年龄排序。实现不难&#xff0c;代码如下&#xff1a;这种方法由于sort方法的第二个参数是Comparator 所以你要写一个实现类(我这里…

读芯术python教程答案_攻略Python的免费书单:走进编程,从这五本书开始

全文共1245字&#xff0c;预计学习时长5分钟图源&#xff1a;unsplashPython一向是数据科学家最青睐的编程语言&#xff0c;它的语法相对简单、易于学习。除了机器学习数据库之外&#xff0c;还有非常活跃的开发人员社区&#xff0c;维护着各种库&#xff0c;用于数据分析、操作…

JAVA minaio模型_分布式系统之Java IO模型

1.正确理解IO定义IO涉及两个系统对象&#xff0c;一个是用户进程&#xff0c;一个是系统内核阻塞IO和非阻塞IO 针对是对用户进程来讲的调用函数。同步IO和异步IO针对的是系统内核。select,poll,epoll是Linux系统使用最多的IO多路复用机制&#xff0c;采用的都是同步IO。IO读取过…

java 写一个计算器_java编写一个计算器类

展开全部import java.awt.BorderLayout;import java.awt.Color;import java.awt.GridLayout;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.ImageIcon;import javax.swing.JButton;import javax.swing.JFrame;import javax.swin…

java文本框背景_用Java编写小程序(包含组合框下拉和文本框)变换背景颜色

展开全部代码如下&#xff1a;import java.awt.Color;import java.awt.Dimension;import java.awt.FlowLayout;import java.util.HashMap;import java.util.Map;import javax.swing.JComboBox;import javax.swing.JFrame;import javax.swing.JTextField;public class App exten…

关于java_关于Java基础

一、方法的重载与重写方法重载(overload)是让类以统一的方式处理不同类型数据的一种手段。调用方法时通过传递给它们的不同个数和类型的参数来决定具体使用哪个方法&#xff0c;这就是多态性。所谓方法重载是指在一个类中&#xff0c;多个方法的方法名相同&#xff0c;但是参数…

yii2 提供接口给java_yii2写api接口步骤

yii2写api接口步骤Yii2如何实现RESTful风格的API(推荐&#xff1a;《YII教程》 )1、建立单独的应用程序为了增加程序的可维护性&#xff0c;易操作性&#xff0c;我们选择新建一套应用程序&#xff0c;这也是为了和前台应用、后台应用区分开操作。在WEB前端(frontend)和后端(ba…

java caller_js中的caller和callee属性

caller返回一个对函数的引用&#xff0c;该函数调用了当前函数。functionName.callerfunctionName 对象是所执行函数的名称。如果一个函数f是在全局作用域内被调用的,则f.caller为null,相反,如果一个函数是在另外一个函数作用域内被调用的,则f.caller指向调用它的那个函数.该属…

java第二部分项目_Java_第二次作业:项目构思与实现

写在最前&#xff1a;我我我我我我靠&#xff0c;以后再也不再ddl截止前1小时调试程序了&#xff01;之前在DDL前1小时修改程序&#xff0c;当我改完后&#xff0c;我想着&#xff0c;再把之前的测试样例跑一遍&#xff0c;如果都对就OK了。就在这时&#xff0c;问题出现了&…

java变量用来干嘛_Java

一、Maven的简介1、Maven是什么&#xff1f;Apache Maven是一个软件项目管理的综合工具。基于项目对象模型(POM)的概念&#xff0c;提供了帮助管理构建、文档、报告、依赖、发布等方法&#xff0c;Maven简化和标准化项目建设过程。处理编译&#xff0c;分配&#xff0c;文档&am…

mysql 视图 数据相加_MySQL

查看安装路径ps -ef|grep mysql1&#xff0c;配置linux虚拟机&#xff0c;修改IP????? vim /etc/sysconfig/network-scripts/ifcfg-eth02&#xff0c;配置完网卡之后&#xff0c;执行清空命令3&#xff0c;reboot查看生产环境上传文件MySQL5.5编译方式安装过程参考连接&am…

java 任意代码执行漏洞_php-fpm在nginx特定环境下的任意代码执行漏洞(CVE-2019-11043)...

目录0x01 漏洞介绍0x02 漏洞影响0x03 漏洞复现0x01 漏洞介绍在长亭科技举办的 Real World CTF 中&#xff0c;国外安全研究员 Andrew Danau 在解决一道 CTF 题目时发现&#xff0c;向目标服务器 URL 发送%0a符号时&#xff0c;服务返回异常&#xff0c;疑似存在漏洞。在nginx上…

c enum能像java一样吗_不一样的Java Enum

Emum是在Java5中引入的新特性&#xff0c;从那开始&#xff0c;它被广泛的用在不同的Java应用中&#xff0c;相比于C和C的Enum&#xff0c;Java的Enum功能更加强大。但是很多开发人员暂时还没意识到它的强大之处&#xff0c;在Enum的一些细节问题上把握的还不到位。Enum的特性及…