MySQL - mvcc

mvcc 是什么?

MVCC(多版本并发控制)是一种数据库并发控制机制,旨在提高数据库的并发性,避免锁定操作,从而减少等待和提高性能。MVCC 主要解决数据库读写操作之间的线程安全问题。

MVCC 主要有两种读取数据的方式:

  1. 快照读(Snapshot Read)

    • 快照读是一种普通的查询操作(例如 SELECT 语句),在读取数据时不需要加锁。
    • 这意味着多个事务可以同时进行快照读操作,而不会争夺读取锁,从而提高了读取效率。
    • 但快照读可能会读取到历史版本的数据,因为它不阻止其他事务对数据进行更改。
  2. 当前读(Current Read)

    • 当前读是一种悲观锁的操作,它会对读取的数据进行加锁,以确保读取的数据是最新的版本。
    • 例如,使用 SELECT ... FOR UPDATESELECT ... LOCK IN SHARE MODE 进行当前读,或在更新、插入和删除操作中使用排他锁。
    • 当前读保证了数据的一致性,但会导致读写操作之间的争用,可能降低并发性能。

MVCC 的优势在于它允许读取操作并发执行而不争夺锁,从而提高了数据库的并发性和性能。同时,MVCC 也能够保证数据的一致性,因为它允许读取到历史版本的数据,而不会读取到正在被其他事务修改的数据。

事务的特性与MVCC实现

  • MVCC 通过数据版本控制来支持事务的特性。
  • 原子性(A)通过 undolog 实现,持久性(D)通过 redolog 实现,一致性(C )是通过 undologredolog 和隔离性(I)一起实现的。以我的理解就是AID -> C

事务的隔离级别与MVCC

  • 不同的事务隔离级别在MVCC中有不同的实现方式:

    • 读未提交:允许读取尚未提交的数据变更,可能导致脏读、幻读或不可重复读。
    • 读已提交:允许读取已经提交的数据,可能导致幻读和不可重复读。
    • 可重复读:对同一字段的多次读取结果都是一致的,可能导致幻读。
    • 可串行化:最高的隔离级别,通过MVCC完全隔离事务。

MVCC实现原理

  • MVCC的核心实现依赖如下:

    • trx_id:事务ID,每次事务操作都会增加。
    • roll_pointer:回滚指针,用于查找上一个版本的数据,与undolog协同实现回滚。
    • readview:读取视图,用于限制当前事务可读取的数据版本。
  • 当执行SELECT查询时,数据可能有多个版本,但readview决定了当前事务能够读取哪个版本。

MVCC如何实现不同隔离级别

  • 在MVCC中,不同隔离级别:

    • 读已提交:每个快照读都生成并获取最新的readview,以确保读取已提交的数据版本。
    • 可重复读:只有在同一个事务的第一个快照读时才会创建新的readview,之后的每次快照读都使用同一个readview,确保查询结果一致。

幻读问题的解决

  • 幻读问题是指在并发事务中,一个事务在两次查询之间,另一个事务插入或删除了数据,导致第一个事务看到了不一致的数据。
  • MVCC通过版本控制和锁机制来解决幻读问题。在可重复读隔离级别下,通过行锁和间隙锁(gap锁)来阻止其他事务插入或删除相关数据,从而解决幻读问题。

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

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

相关文章

【web前端】web前端设计入门到实战第二弹——面试题总结+答案

这里写目录标题 一、选择题二、填空题 一、选择题 1、表格的主要作用是( B )。 A.网页排版布局 B.显示数据 C.处理图像 D.优化网站 2、如果表格的边框不显示,应设置border的值为( B )。 A.1 B.0 C.2 D.3 3、定义单元格…

RetentionPolicy枚举类

包名package java.lang.annotation 作用 注释保留策略。此枚举类型的常量描述用于保留注释的各种策略。它们被使用与{ Retention}元注释类型一起指定注释要保留多长时间。 属性 SOURCE编译器将丢弃注释。CLASS注释将由编译器记录在类文件…

threejs(3)-详解材质与纹理

一、Matcap(MeshMatcapMaterial)材质原理与应用 Matcap是一张含有光照信息的贴图,通常是直接截取材质球截图来使用。因此Matcap可以很好的模拟静止光源下的光照效果。 最直接的方式就是直接使用在View空间下的模型法向量的xy分量去采样Matcap。 另外还有一种常见…

EPPlus库的安装和使用 C# 中 Excel的导入和导出

安装 工具栏->NuGet 包管理器->管理解决方案的NuGet程序包 安装到当前项目中 使用 将 DataGridView 数据导出为Excel 首先,需要将数据DataGridView对象转换为DataTable private void btnExport_Click(object sender, EventArgs e) {// 1.将当前页面的data…

基于Raft解决“幽灵复现”问题

3.1 关于Raft日志恢复 首先,我们聊一下Raft的日志恢复,在 Raft 中,每次选举出来的Leader一定包含已经Committed的数据(抽屉原理,选举出来的Leader是多数中数据最新的,一定包含已经在多数节点上Commit的数据),新的Leader将会覆盖其他节点上不一致的数据。虽然新选举出来…

json-server工具准备后端接口服务环境

1.安装全局工具json-server(全局工具仅需要安装一次) 官网:json-server - npm 点击Getting started可以查看使用方法 在终端中输入yarn global add json-server或npm i json-server -g 如果输入json-server -v报错 再输入npm install -g j…

Elasticsearch之mapping

文章目录 以显式的方式创建一个映射查看某个具体索引的mapping定义向已存在的映射中添加一个新的属性查看映射中指定字段的定义信息更新已存在映射的某个字段 1、 官方文档地址 2、 字段类型 1、定义:映射是定义文档及其包含的字段如何存储和索引的过程。 2、每个…

电影评分数据分析案例-Spark SQL

# cording:utf8from pyspark.sql import SparkSession from pyspark.sql.types import IntegerType, StringType, StructType import pyspark.sql.functions as Fif __name__ __main__:# 0.构建执行环境入口对象SparkSessionspark SparkSession.builder.\appName(movie_demo)…

typedef __packed struct 中的__packed意义

typedef __packed struct 是C语言中用于定义紧凑结构体的语法。__packed关键字用于告诉编译器不要为结构体成员添加填充字节,从而使得结构体的大小更加紧凑。typedef关键字用于为数据类型定义一个新的名称。 下面是一个使用__packed和typedef的示例代码&#xff1a…

【网络爬虫 | Python】数字货币ok链上bitcoin大额交易实时爬取,存入 mysql 数据库

文章目录 一、网站分析二、js 逆向获取 X-Apikey三、python 调用 js 获取 X-Apikey四、python 爬虫部分五、mysql 数据库、日志、配置文件、目录结构六、结尾 一、网站分析 oklink:https://www.oklink.com/ btc 大额交易:https://www.oklink.com/btc/tx-…

蜂鸟物流开放平台-配送系统

文章目录 引言API 接入指南1.1 Maven 引入 SDK1.2 pom.xml包依赖冲突解决引言 API 接入指南 https://gitee.com/ash_floating_around/anubis-openapi-sdk 上线前将 Config 中 IS_SANDBOX 值设为 false,并填写正式环境的 APP_ID 和 SECRET_KEY。 1.1 Maven 引入 SDK <d…

解决 edge 浏览器开发者工具出不来的问题

文章目录 猜测原因问题现象尝试过程最终解决办法C盘爆满解决经过&#xff08;拆东墙补西墙&#xff09; 猜测原因 windows 系统更新导致电脑管家C盘迁移导致&#xff08;我C盘爆满了&#xff0c;每天提醒看着膈应&#xff0c;想着清理一下&#xff09; 问题现象 按F12 和 右键…

Java零基础入门-算术运算符

本文旨在帮助零基础的读者快速了解Java中的算术运算符&#xff0c;包括基本的加减乘除运算符、取余运算符、自增自减运算符等常见的数学运算符。 在学习本文前&#xff0c;需要先掌握基本的Java语法&#xff0c;包括数据类型、变量、赋值语句等。 前言 在编写Java程序时&…

layui的一些问题

为什么table.render, ins1.config有时候获取的值是上一次的?例如ins1.conf.page.curr? 这是一段table.render代码 let ins1 table.render({...})一般情况下ins1.conf可以获得表格的当前页,页数等;但是有时候获得的页数是上一次的;主要是因为在table.reload后没有继续赋值的…

题目 1009: [编程入门]数字的处理与判断(python详解)——练气二层后期

✨博主&#xff1a;命运之光 &#x1f984;专栏&#xff1a;算法修炼之练气篇&#xff08;C\C版&#xff09; &#x1f353;专栏&#xff1a;算法修炼之筑基篇&#xff08;C\C版&#xff09; &#x1f352;专栏&#xff1a;算法修炼之练气篇&#xff08;Python版&#xff09; ✨…

爬虫知识之BeautifulSoup库安装及简单介绍

一. 前言 在前面的几篇文章中我介绍了如何通过Python分析源代码来爬取博客、维基百科InfoBox和图片,其文章链接如下: 其中核心代码如下: # coding=utf-8 import urllib import re #下载静态HTML网页 url=http://www.csdn.net/ content = urllib.urlopen(url).read…

【2024秋招】小米中间件后端开发一面2023-9-13-base武汉

1 自我介绍 2 快手实习 2.1 讲讲你写的curd启动器&#xff0c;做了哪些工作呢 答&#xff1a; 2.2 网上也有一些开源的curd代码生成器&#xff0c;你为什么需要自研呢&#xff08;重要&#xff09; 答&#xff1a; &#xff08;1&#xff09;这个必须得自研&#xff0c;因…

vue3检测是手机还是pc端,监测视图窗口变化

1.超小屏幕&#xff08;手机&#xff09; 768px以下 2.小屏设备&#xff08;平板&#xff09; 768px-992px 3.中等屏幕&#xff08;旧式电脑&#xff09; 992px-1200px 4.大屏设备&#xff08;现代电脑&#xff09; 1200px以上 <script setup name"welcome"> i…

最新校园说明会日程安排-ABeam(德硕)旗下艾宾信息技术开发(上海) 德硕管理咨询(深圳)

艾宾信息技术开发&#xff08;上海&#xff09; 2024校园招聘 招聘岗位 公司介绍 福利待遇 联系我们 行程一览 华东理工大学校园宣讲会 日期&#xff1a;2023年10月23日&#xff08;周一&#xff09; 时间&#xff1a;14:00-16:00 地点&#xff1a;上海市徐汇区梅陇…

用桥接模式(Bridge)实现开放接口系统

桥接模式是设计模式中比较难的一种&#xff0c;其原文叙述是&#xff1a;“将抽象部分与它的具体实现部分分离&#xff0c;使它们都可以独立地变化&#xff0c;属于结构型模式。”表述也很抽象&#xff0c;其本质是通过一个抽象类A的构造函数传入一个Interface类B作为参数&…