MySQL-多版本并发控制MVCC

news2025/4/19 10:44:15

文章目录

  • 一、多版本并发控制MVCC
  • 二、undo log(回滚日志)
  • 二、已提交读
  • 三、可重复读
  • 总结


一、多版本并发控制MVCC

MVCC是多版本并发控制(Multi-Version Concurrency Control),是MySQL中基于乐观锁理论实现隔离级别的方式,用于实现已提交读和可重复读隔离级别的实现,也经常称为多版本数据库。MVCC机制会生成一个数据请求时间点的一致性数据快照 (Snapshot), 并用这个快照来提供一定级别 (语句级或事务级) 的一致性读取。从用户的角度来看,好象是数据库可以提供同一数据的多个版本(系统版本号和事务版本号)。事务的隔离性就是锁机制加MVCC体现的。
MVCC多版本并发控制中,读操作可以分为两类:
1、快照读(snapshot read)
读的是记录的数据快照,可以理解给数据拍了一张照片,不用加锁。如select
2、当前读(current read)
读取的是当前事务记录的最新数据库版本,并且返回第一次select数据快照的记录。如insert,delete,update,select…lock in share mode/for update

已提交读和可重复读的底层实现原理:通过MVCC多版本并发控制实现并发读取方式:快照读。InnoDB提供了两个读取操作:锁定读非锁定读。锁定读相关内容在锁机制里有提到,间隙锁、排它锁与共享锁等;非锁定读就是MVCC提供的快照读,它实现依赖于依赖底层的一个技术,undolog回滚日志;
undolog回滚日志的主要作用:事务发生错误时回滚rollback,提供MVCC的非锁定读(快照读),查快照上的数据而不是最新的数据;

二、undo log(回滚日志)

undo log:回滚日志,保存了事务发生之前的数据的一个版本,用于事务执行时的回滚操作,也就是rollback操作;同时也是实现多版本并发控制(MVCC)下读操作的关键技术,提供MVCC的非锁定读(快照读)。
实现回滚日志的两个关键:DB_TRX_ID:事务IDDB_ROLL_PTR:回滚指针

在这里插入图片描述

通过上面的图片可以了解到,每一行记录实际上有多个版本,每个版本的记录除了数据本身之外,增加了其它字段 ;在记录行中隐式的记录了事务ID和回滚指针,这些隐式数据是给MySQL看的:
1、开启事务时,MySQL会给事务分配事务ID,同一个事务的事务ID是不变的,不同的事务ID不同;
2、事务修改后的数据,放在表中原来的位置上,修改之前的数据会被放置在undo log中(缓存中);旧数据与新数据通过回滚指针链接,类似链表的结构,通过链表就可以找到之前的旧数据,实现回滚操作;

二、已提交读

已提交读:可以解决事务并行的脏读问题,但是不能解决不可重复读和幻读问题。

//设置事务的隔离级别为 已提交读
set tx_isolation='READ_COMMITTED';

1、已提交读如何解决脏读问题?
每次select都会产生一次新的数据快照,前提是数据被事务成功commit过了,在数据没有被commit之前,每次读的数据都是第一次select的结果;当事务成功commit之后,select产生最新的数据快照,此时会发生不可重复读、幻读
2、为什么已提交读无法解决不可重复读、幻读?
因为每次select都会产生一次新的数据快照,其它事务更新以后成功commit,会导致当前事务再select的时候产生了数据更新后的数据快照,从而发生不可重复读和幻读。

三、可重复读

可重复读:可以解决事务并发产生的脏读、不可重复读问题;一定程度上解决幻读问题。

//设置事务的隔离级别为 可重复读
set tx_isolation='REPEATABLE-READ';

1、如何解决脏读问题?
也是通过数据快照解决的脏读问题;
2、如何解决不可重复读?
可重复读隔离级别下,数据快照只在第一次select时候产生,不会因为其它事务成功commit就改变当前的数据快照。当前事务再次select时,仍然查看的是第一次select的数据快照。
3、为什么能部分解决幻读问题?
但是在事务执行update时,进行当前读,会读取到其它事务成功commit的数据;此时当前的事务发生更新,再执行select时,会将修改后的数据也显示出来,显示的结果就是第一次select的数据快照和修改后的数据


总结

由于MVCC,所以每一行记录实际上有多个版本,快照内容读取原则:
1、版本未提交无法读取生成快照 ;
2、版本已提交,但是在快照创建后提交的,无法读取 ;
3、版本已提交,但是在快照创建前提交的,可以读取 。所以在已提交读隔离级别下会产生不可重复读;
4、当前事务内自己的更新,可以读到 。所以在可重复读隔离级别下会产生幻读。

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

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

相关文章

目标检测与分割:深度学习在视觉中的应用

🔍 PART 1:目标检测(Object Detection) 1️⃣ 什么是目标检测? 目标检测是计算机视觉中的一个任务,目标是让模型“在图像中找到物体”,并且判断: 它是什么类别(classif…

杰弗里·辛顿:深度学习教父

名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 杰弗里辛顿:当坚持遇见突破,AI迎来新纪元 一、人物简介 杰弗…

STM32蓝牙连接Android实现云端数据通信(电机控制-开源)

引言 基于 STM32F103C8T6 最小系统板完成电机控制。这个小项目采用 HAL 库方法实现,通过 CubeMAX 配置相关引脚,步进电机使用 28BYJ-48 (四相五线式步进电机),程序通过蓝牙连接手机 APP 端进行数据收发, OL…

第一个Qt开发的OpenCV程序

OpenCV计算机视觉开发实践:基于Qt C - 商品搜索 - 京东 下载安装Qt:https://download.qt.io/archive/qt/5.14/5.14.2/qt-opensource-windows-x86-5.14.2.exe 下载安装OpenCV:https://opencv.org/releases/ 下载安装CMake:Downl…

TCP 如何在网络 “江湖” 立威建交?

一、特点: (一)面向连接 在进行数据传输之前,TCP 需要在发送方和接收方之间建立一条逻辑连接。这一过程类似于打电话,双方在通话前需要先拨号建立连接。建立连接的过程通过三次握手来完成,确保通信双方都…

【小白训练日记——2025/4/15】

变化检测常用的性能指标 变化检测(Change Detection)的性能评估依赖于多种指标,每种指标从不同角度衡量模型的准确性。以下是常用的性能指标及其含义: 1. 混淆矩阵(Confusion Matrix) 定义:统…

数据结构——二叉树(中)

接上一篇,上一篇主要讲解了关于二叉树的基本知识,也是为了接下来讲解关于堆结构和链式二叉树结构打基础,其实无论是堆结构还是链式二叉树结构,都是二叉树的存储结构,那么今天这一篇主要讲解关于堆结构的实现与应用 堆…

02-MySQL 面试题-mk

文章目录 1.mysql 有哪些存储引擎、区别是什么?1.如何定位慢查询?2.SQL语句执行很慢,如何分析?3.索引概念以及索引底层的数据结构4.什么是聚簇索引什么是非聚簇索引?5.知道什么叫覆盖索引嘛 ?6.索引创建原则有哪些?7.什么情况下索引会失效 ?8.谈一谈你对sql的优化的经验…

#include<bits/stdc++.h>

#include<bits/stdc.h> 是 C 中一个特殊的头文件&#xff0c;其作用如下&#xff1a; 核心作用 ​​包含所有标准库头文件​​ 该头文件会自动引入 C 标准库中的几乎全部头文件&#xff08;如 <iostream>、<vector>、<algorithm> 等&#xff09;&…

在企业级部署中如何优化NVIDIA GPU和容器环境配置:最佳实践与常见误区20250414

在企业级部署中如何优化NVIDIA GPU和容器环境配置&#xff1a;最佳实践与常见误区 引言 随着AI和深度学习技术的迅速发展&#xff0c;企业对GPU加速计算的需求愈加迫切。在此过程中&#xff0c;如何高效地配置宿主机与容器化环境&#xff0c;特别是利用NVIDIA GPU和相关工具&…

Spring Boot 项目三种打印日志的方法详解。Logger,log,logger 解读。

目录 一. 打印日志的常见三种方法&#xff1f; 1.1 手动创建 Logger 对象&#xff08;基于SLF4J API&#xff09; 1.2 使用 Lombok 插件的 Slf4j 注解 1.3 使用 Spring 的 Log 接口&#xff08;使用频率较低&#xff09; 二. 常见的 Logger&#xff0c;logger&#xff0c;…

[react]Next.js之自适应布局和高清屏幕适配解决方案

序言 阅读前首先了解即将要用到的两个包的作用 1.postcss-pxtorem 自动将 CSS 中的 px 单位转换为 rem 单位按照设计稿尺寸直接写 px 值&#xff0c;由插件自动计算 rem 值 2.amfe-flexible 动态设置根元素的 font-size&#xff08;即 1rem 的值&#xff09;根据设备屏幕宽度和…

STM32H503CB升级BootLoader

首先&#xff0c;使用SWD接口&#xff0c;ST-LINK连接电脑和板子。 安装SetupSTM32CubeProgrammer_win64 版本2.19。 以下是接线和软件操作截图。

在Apple Silicon上部署Spark-TTS:四大核心库的技术魔法解析!!!

在Apple Silicon上部署Spark-TTS&#xff1a;四大核心库的技术魔法解析 &#x1f680; &#xff08;M2芯片实测&#xff5c;Python 3.12.9PyTorch 2.6.0全流程解析&#xff09; 一、核心库功能全景图 &#x1f50d; 在Spark-TTS的部署过程中&#xff0c;pip install numpy li…

VMWare 16 PRO 安装 Rocky8 并部署 MySQL8

VMWare 16 PRO 安装 Rocky8 并部署 MySQL8 一.Rocky OS 下载1.官网二.配置 Rocky1.创建新的虚拟机2.稍后安装系统3.选择系统模板4.设置名字和位置5.设置大小6.自定义硬件设置核心、运存和系统镜像7.完成三.启动安装1.上下键直接选择安装2.回车安装3.设置分区(默认即可)和 roo…

cursor如何回退一键回退多个文件的修改

当我们使用 Cursor 写代码时&#xff0c;起初可能操作得很顺利&#xff0c;但某次更改或许会让代码变得面目全非。这时候如果没有使用 Git 该怎么办呢&#xff1f;别担心&#xff0c;Cursor 已经为我们考虑到了。 具体的操作如下&#xff1a; 当我们要取消某次操作时&#xf…

基于RV1126开发板的口罩识别算法开发

1. 口罩识别简介 口罩识别是一种基于深度学习的判断人员有没有戴口罩的分类算法&#xff0c;能广泛的用于安防、生产安全等多种场景。本算法先基于人脸检测和人脸标准化获取的标准人脸&#xff0c;然后输入到口罩识别分类算法进行识别。 本人脸检测算法在数据集表现如下所示&am…

PyCharm显示主菜单和工具栏

显示主菜单 新版 PyCharm 是不显示主菜单的&#xff0c;要想显示主菜单和工具栏&#xff0c;则通过 “视图” → “外观” &#xff0c;勾选 “在单独的工具栏中显示主菜单” 和 “工具栏” 即可。 设置工具栏 此时工具栏里并没有什么工具&#xff0c;因此我们需要自定义工具…

Java工程行业管理软件源码 - 全面的项目管理工具 - 工程项目模块与功能一览

工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离构建工程项目管理系统 项目背景 随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性&#xff0c;公司对内部工程管理的提升提…

Redis 高可用集群搭建与优化实践

在分布式系统中,缓存技术用于提升性能和响应速度。 Redis 作为一款高性能的键值存储系统,广泛应用于缓存、消息队列和会话管理等场景。随着业务规模的扩大,单机 Redis 的性能和可用性逐渐无法满足需求。 因此,搭建高可用的 Redis 集群可以解决这一问题。我将详细介绍 Red…