当前位置: 首页 > news >正文

理解 mvcc

mvcc 多版本并发控制,
提高数据库的并发性能 —— 让“读”和“写”互不阻塞!
什么意思?
传统方式:读数据要加“读锁”,写数据要加“写锁”,读写冲突 → 等待
MVCC 方式:读走快照,写走新版本,互不影响 ✅
🎯 所以,MVCC 的诞生,首先是为了性能

然后 MVCC + “可重复读”隔离级别,确实能防止快照读下的幻读 ,
幻读就是 如果事务A 第一次查询结果为3条, 这个事务还没结束, 其他事务 插入了 数据 并且 已经提交 , 第二次查询就是 4条, 一个事务同样查询条件的 两次查询的结果不一致, 这就是幻读

在事务开始时,看到的是一个属于自己的“快照”,即使别人提交了新数据,你也看不到,直到事务结束。

mvcc 的工作原理是 : 数据库(比如 MySQL InnoDB)会给每行数据加上几个“隐藏字段” :
最后修改这行的事务ID ,
指向上一个版本的“回滚指针”

当你更新一行数据时,旧数据不会立刻被覆盖,而是:
保存为一个“旧版本”;
新数据作为一个“新版本”;
通过指针连成一条“版本链”。
你执行查询时,数据库根据你的事务开始时间,决定你该看到哪个版本的数据。

这些“旧版本”什么时候删除?
当确认没有任何事务还需要它时,MySQL 的后台线程会清理掉这些旧版本,释放空间

当然,如果仅仅是 mvcc 是不能防止当前读 的幻读的, 并不能 防止当前读的幻读 , 比如一个事务中, 同时有两条 相同查询条件的 sql, 其中 有条语句 加了 for update , 那加了 for update 的语句走的不是快照读, 是当前读( 读取最新的) , 那两次查询的结果不一样 , 那这就是幻读了

如果 加锁, mvcc 间隙锁 , 其他事务插入不了数据了, 或者即将插入的地方在锁的范围内 (在间隙锁范围内), 那就肯定不会幻读 . 比如:

-- 事务A
BEGIN;
SELECT * FROM users WHERE age > 25 FOR UPDATE;  -- 加锁,包括间隙锁
-- 此时事务B尝试插入 age=28
-- ❌ 事务B会被阻塞,无法插入,直到事务A提交
SELECT * FROM users WHERE age > 25 FOR UPDATE;  -- 仍然只有原来的记录
COMMIT;
http://www.dtcms.com/a/409924.html

相关文章:

  • 【网络编程】TCP 粘包处理:手动序列化反序列化与报头封装的完整方案
  • 数据库MVCC
  • 如何用AI工具开发一个轻量化CRM系统(七):AI生成pytest测试脚本
  • qData:一站式开源数据中台
  • 国外中文网站排行在线图片编辑网站源码
  • [数据结构]优先级队列
  • ARM内部寄存器
  • Laravel + UniApp AES加密/解密
  • 5G开户时切片配置参数详解
  • 面向新质生产力,职业院校“人工智能”课程教学解决方案
  • wap网站如何做福建外贸网站
  • ElasticSearch-提高篇
  • 第6篇、Flask 表单处理与用户认证完全指南:从零到实战
  • Visual Studio 2013 Update 4 中文版安装步骤(带TFS支持)附安装包​
  • 珠海 网站建设注册安全工程师题库
  • 上手 cpp-httplib:轻量级 C++ HTTP 库的安装与实战指南
  • 突破文档型数据库迁移困境:金仓多模方案破解电子证照系统国产化难题
  • 网站手机客户端开发wordpress制造商单页
  • Net 》》C# 》》try finally 执行顺序
  • 在 Unity 项目中使用 FFMpeg 进行音频转码(WAV 转 MP3)
  • 使用Java将Word文件转换为PNG图片
  • 如何用Fail2ban保护Linux服务器?防止SSH暴力破解教程
  • 开源 C# 快速开发(五)自定义控件--仪表盘
  • 华为FreeClip 2耳夹耳机:让「戴着不摘」成为新的使用习惯
  • 算法继续刷起-2025年09月26日
  • AI笔记在学习与工作中的高效运用
  • QML学习笔记(十四)QML的自定义模块
  • ubuntu一键安装vscode: 使用官方 APT 仓库
  • python做网站的 框架企业邮箱什么样子
  • 学习游戏制作记录(爆炸敌人的制作)