mysql mvcc 锁 关系

多版本并发控制(MVCC)是一种用于数据库并发控制的机制,它可以在保证数据一致性的同时,提高数据库的并发性能。下面结合 MVCC 机制,详细阐述常见的四种事务隔离级别(读未提交、读已提交、可重复读、串行化)与各种锁(共享锁、排他锁、记录锁、间隙锁、临键锁)之间的关系。

读未提交(Read Uncommitted)

  • MVCC 机制:在该隔离级别下,MVCC 机制基本不发挥作用。因为此隔离级别允许一个事务读取另一个未提交事务的数据,它更侧重于提高并发性能,而不是通过 MVCC 来保证数据的一致性。事务在读取数据时,不会基于 MVCC 去判断数据版本,而是直接读取最新的数据,无论该数据是否已经提交。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 此隔离级别对锁的使用进行了极大程度的弱化。一般情况下,普通的读操作不会加共享锁,写操作(如 UPDATEDELETEINSERT)虽可能会对受影响的行加排他锁,但这种锁的限制作用相对较弱,因为即使有排他锁存在,其他事务也能读取未提交的数据,会导致脏读。
  • 记录锁、间隙锁和临键锁
    • 通常不会使用记录锁、间隙锁和临键锁。由于不依赖 MVCC 来保证数据一致性,也不需要这些锁来防止不可重复读和幻读问题。

读已提交(Read Committed)

  • MVCC 机制:MVCC 在该隔离级别中发挥重要作用。普通的 SELECT 查询采用快照读,基于 MVCC 读取已提交的数据版本。每个语句执行时,都会生成一个新的快照,这使得在同一个事务内不同时刻执行相同的查询可能会得到不同的结果,从而可能出现不可重复读的问题。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通的 SELECT 查询默认不会加共享锁,而是利用 MVCC 进行快照读。但当使用 SELECT ... LOCK IN SHARE MODE 时,会对查询结果集的行加共享锁,允许其他事务同时读取这些行,但阻止其他事务对这些行加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句以及 SELECT ... FOR UPDATE 会对受影响的行加排他锁。并且,这些锁是语句级别的,即锁只在语句执行期间有效,语句执行完毕后锁就会释放。
  • 记录锁、间隙锁和临键锁
    • 记录锁:在执行 SELECT ... FOR UPDATE 或写操作时,会对读取或修改的行加记录锁。
    • 间隙锁和临键锁:一般不会使用间隙锁和临键锁。因为 MVCC 的快照读机制和语句级别的锁控制,使得该隔离级别允许幻读的存在,无法阻止其他事务在查询范围的间隙插入新记录。

可重复读(Repeatable Read)

  • MVCC 机制:MVCC 是该隔离级别实现可重复读特性的关键。在事务开始时,会创建一个全局的快照,事务内的所有 SELECT 查询都基于这个快照进行,保证在同一个事务内多次读取相同数据的结果是一致的。不过,对于当前读操作(如 SELECT ... FOR UPDATEUPDATEDELETE),MVCC 机制与锁机制共同作用来保证数据的一致性。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通 SELECT 查询采用快照读,不会加共享锁。使用 SELECT ... LOCK IN SHARE MODE 时,会对查询结果集的行加共享锁,防止其他事务对这些行加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句以及 SELECT ... FOR UPDATE 会对受影响的行加排他锁。这些锁会在事务结束(提交或回滚)时才释放。
  • 记录锁、间隙锁和临键锁
    • 记录锁:在执行 SELECT ... FOR UPDATE 或写操作时,会对读取或修改的行加记录锁。
    • 间隙锁:当进行范围查询(如 SELECT ... FOR UPDATE 或写操作涉及范围条件)且查询条件没有精确匹配到所有记录时,会对查询范围对应的间隙加上间隙锁,防止其他事务在这些间隙插入新记录。这是为了弥补 MVCC 在处理范围插入时可能出现幻读的不足。
    • 临键锁:临键锁是记录锁和间隙锁的组合。在可重复读隔离级别下,对于索引记录,InnoDB 通常使用临键锁来防止幻读。例如,对唯一索引进行等值查询时,如果记录存在,使用记录锁;如果记录不存在,使用间隙锁;对于普通索引,一般使用临键锁。

串行化(Serializable)

  • MVCC 机制:在串行化隔离级别下,MVCC 机制基本不发挥作用。因为该隔离级别要求事务串行执行,所有的读写操作都需要排队进行,以保证数据的绝对一致性。它不依赖 MVCC 的多版本特性来处理并发,而是通过严格的锁机制来实现事务的隔离。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通的 SELECT 查询会自动对查询结果集的行加共享锁,保证在当前事务读取数据期间,其他事务不能对这些数据加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句会自动对受影响的行加排他锁。由于事务是串行执行的,任何事务的读写操作都需要等待前面事务释放相应的锁,并发性能最差,但能完全避免脏读、不可重复读和幻读问题。
  • 记录锁、间隙锁和临键锁
    • 在串行化隔离级别下,记录锁、间隙锁和临键锁都会被使用,以确保事务之间的完全隔离。无论是读取还是修改数据,都会通过这些锁来保证同一时间只有一个事务可以访问特定的数据资源,从而实现事务的串行执行。

综上所述,MVCC 机制和锁机制在不同的事务隔离级别中相互配合,共同影响着数据库的并发性能和数据一致性。较低的隔离级别更依赖 MVCC 来提高并发性能,而较高的隔离级别则更强调锁机制来保证数据的严格一致性。

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

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

相关文章

2502vim,vim文本对象中文文档

介绍 文本块用户(textobj-user)是一个可帮助你毫不费力地创建自己的文本对象的Vim插件. 因为有许多陷阱需要处理,很难创建文本对象.此插件隐藏了此类细节,并提供了声明式定义文本对象的方法. 你可用正则式来定义简单的文本对象,或使用函数来定义复杂的文本对象.如… 文本对…

AUTOSAR面试题集锦(1)

最基础概念 目录 最基础概念 什么是AUTOSAR?AUTOSAR到底做了什么? AUTOSAR的结构是什么样的?分为哪几层? MCAL开发 什么是MCAL? 使用过EB吗?怎样使用EB配置MCAL工程? autosar4.3.1和4.4.0有什么区别? 什么是复杂驱动? 为什么使用多核?AUTOSAR提供了几种多核…

【算法】动态规划专题⑧ —— 分组背包问题 python

目录 前置知识进入正题实战演练总结 前置知识 【算法】动态规划专题⑤ —— 0-1背包问题 滚动数组优化 python 进入正题 分组背包问题的详细解析 1. 问题定义 在 分组背包问题 中,物品被划分为若干组,每组内的物品 互斥(只能选择其中一个或…

LLM:DeepSeek 系列(二)

原文链接 3、DeepSeek-V2 DeepSeek-V2 发布于 2024 年 5 月,为多领域专家(MoE)语言模型,包含总共 2360 亿个参数,其中每个词元激活 210 亿个参数,并支持 12.8 万个词元的上下文长度。DeepSeek-V2 采用包括…

AtCoder Beginner Contest 391(A~E题题解)

A - Lucky Direction 思路&#xff1a;纯模拟的一个水题 #include <bits/stdc.h> using namespace std; #define int long long string s; signed main() { cin>>s;for(int i0;i<s.size();i){char cs[i];if(cN){cout<<"S";}else if(c…

redis中的hash结构

hash类型也叫散列&#xff0c;其中value是一个无序字典&#xff0c;不用像string类型中的value用jason结构去存储&#xff0c;他的value可以将对象中的每个字段独立存储&#xff0c;而且有个好处&#xff0c;方便修改value值 类似于这样 hash类型的常见命令&#xff1a;

USB子系统学习(四)使用libusb读取鼠标数据

文章目录 1、声明2、HID协议2.1、描述符2.2、鼠标数据格式 3、应用程序4、编译应用程序5、测试 1、声明 本文是在学习韦东山《驱动大全》USB子系统时&#xff0c;为梳理知识点和自己回看而记录&#xff0c;全部内容高度复制粘贴。 韦老师的《驱动大全》&#xff1a;商品详情 …

02.08 多路文件IO

思维导图1&#xff1a; 思维导图2&#xff1a; 高效处理多路文件IO&#xff1a;select、poll和epoll模型详解 在现代网络编程中&#xff0c;高效地监视多个文件描述符的IO状态&#xff08;如可读、可写、异常&#xff09;是至关重要的。本文将详细介绍三种常用的多路文件IO模…

opentelemetry-collector 配置elasticsearch

一、修改otelcol-config.yaml receivers:otlp:protocols:grpc:endpoint: 0.0.0.0:4317http:endpoint: 0.0.0.0:4318 exporters:debug:verbosity: detailedotlp/jaeger: # Jaeger supports OTLP directlyendpoint: 192.168.31.161:4317tls:insecure: trueotlphttp/prometheus: …

基于联合概率密度与深度优化的反潜航空深弹命中概率模型研究摘要

前言:项目题材来自数学建模2024年的D题,文章内容为笔者和队友原创,提供一个思路。 摘要 随着现代军事技术的发展,深水炸弹在特定场景下的反潜作战效能日益凸显,如何最大化的发挥深弹威力也成为重要研究课题。本文针对评估深弹投掷落点对命中潜艇概率的影响进行分析,综合利…

fps动作系统2:手臂动画

文章目录 角色蓝图pawn自动控制玩家 动画蓝图事件图表动画图表状态机时长 随机序列播放器混合空间播放器权重速度 角色蓝图 pawn 自动控制玩家 设置玩家控制器控制此pawn。 动画蓝图 事件图表 更新角色的相关数值 动画图表 设置角色相关动画以及切换规则 状态机 状态…

使用 ElementUI 和 Spring 实现稳定可靠的文件上传和下载功能

前端(ElementUI) 1. 文件上传 使用 el-upload 组件配置上传接口处理上传成功和失败<template><div><el-uploadclass="upload-demo"action="http://your-server-url/upload":on-success="handleSuccess":on-error="handle…

Docker安装pypiserver私服

Docker安装pypiserver私服 1 简介 Python开源包管理工具有pypiserver、devpi和Nexus等&#xff0c;pypiserver安装部署比较简单&#xff0c;性能也不错。 搭建pypiserver私服&#xff0c;可以自己构建镜像&#xff0c;也可以使用官网的docker镜像。 # Github地址 https://g…

[ Spring ] Integrate Spring Boot Service Monitor Prometheus and Grafana

文章目录 Install Prometheus ServerInstall Grafana ServerSpring Prometheus ProjectSpring Prometheus PropertiesSpring Prometheus ApplicationSpring Prometheus ConfigurationSpring Prometheus ControllerConfigure Grafana Dash Board Install Prometheus Server # d…

“现代C++ RAII库:设计、优化及实战应用“

文章目录 代码 示例raii 类的使用示例代码&#xff1a;解释&#xff1a; raii_var 类的使用示例代码&#xff1a;解释&#xff1a; 结合线程使用示例代码&#xff1a;解释&#xff1a; make_raii 函数签名&#xff1a;示例&#xff1a;解释&#xff1a; raii_bind_var 函数签名…

代码随想录day06

242.有效的字母异位词 刚学哈希表想着使用unordered_set来实现&#xff0c;结果无法通过&#xff0c;原因是对字母异位词理解有问题&#xff0c;字母异位词是通过重新排列不同单词或短语的字母而形成的单词或短语&#xff0c;并使用所有原字母一次。对字母出现的次数有要求&am…

Java_双列集合

双列集合特点 存放的是键值对对象&#xff08;Entry&#xff09; Map 因为都是继承Map&#xff0c;所以要学会这些API&#xff0c;后面的类就都知道了 put 有两个操作&#xff0c;添加&#xff08;并返回null&#xff09;或者覆盖&#xff08;返回被覆盖的值&#xff09…

MHTML文件如何在前端页面展示

MHTML文件如何在前端页面展示 需求背景&#xff1a; 目前在给证券公司做项目&#xff0c;但是在使用新系统的过程中&#xff0c;甲方还希望之前之前系统的历史记录可以看到。 最初制定的计划是项目组里面做数据的把原系统页面爬取下来&#xff0c;转成图片&#xff0c;直接给…

解决bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException

解决Spring Boot中MySQL数据库报错“Bad SQL Grammar”的问题 目录 解决Spring Boot中MySQL数据库报错“Bad SQL Grammar”的问题 问题描述解决步骤解决方案结论附&#xff1a;MySql常用配置参数及使用场景 在使用Spring Boot连接MySQL数据库时&#xff0c;有时候会遇到“B…

【AI日记】25.02.08

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】【读书与思考】【AI应用】 探索 AI 应用探索周二有个面试&#xff0c;明后天打算好好准备一下&#xff0c;我打算主要研究下 AI 如何在该行业赋能和应用&#xff0c;以及该行业未来的发展前景和公司痛点&#…