MySQL-MVCC(多版本并发控制)

MySQL中的MVCC(Multi-Version Concurrency Control)是一种并发控制机制,用于提供读-写冲突时的可靠读取。

MVCC通过保存数据在某个时间点的快照来实现这一点,从而避免了传统的锁定方法。在InnoDB存储引擎中,MVCC是通过在每行记录后面保存两个隐藏的列来实现的,这两个列分别保存了这行数据的创建版本号和删除版本号。

创建版本号:事务开始时,会生成一个全局唯一的事务ID,这个ID是事务版本号,每一行数据在被插入或更新时,会将这个版本号作为创建版本号存储。

删除版本号:当行被删除时,并不会立即物理删除,而是将删除版本号存储在该行记录中。

当执行SELECT操作时,MVCC会选择以下行:

创建版本号小于或等于当前事务版本号的行,这意味着它们在事务开始之前已经存在或已创建。

删除版本号大于当前事务版本号或为空的行,这意味着它们在事务开始之前没有被删除。

这样,即使其他事务正在修改数据,也可以提供一致的读取视图。

由于MVCC复杂度较高,实际实现细节可能因存储引擎而异。对于InnoDB存储引擎,通常不需要手动管理版本号,因为这一切都是由InnoDB自动处理的。

以下是一个简单的例子,演示如何在InnoDB中使用MVCC:

-- 假设有一个简单的表users

CREATE TABLE users (

id INT PRIMARY KEY,

name VARCHAR(255),

age INT

);

-- 开始一个新事务

START TRANSACTION;

-- 插入一条记录

INSERT INTO users (id, name, age) VALUES (1, 'Alice', 25);

-- 提交事务

COMMIT;

-- 另一个事务开始后读取users表

START TRANSACTION;

-- 此时,即使另一个事务更新或删除了这条记录,我们仍然能够读取到这条记录的初始版本

SELECT * FROM users WHERE id = 1;

-- 提交事务

COMMIT;

在这个例子中,使用了MVCC来提供一致的读取视图,即使在事务开始后,有其他事务对记录进行了更新或删除操作。

相关推荐
cui_ruicheng1 小时前
MySQL(四):数据类型与字段设计
数据库·mysql
皮皮学姐分享-ppx2 小时前
政府绿色采购数据库(2015-2024.3)
大数据·网络·数据库·人工智能·制造
闪电悠米3 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
DIY源码阁4 小时前
JavaSwing航班订票管理系统 - MySQL版
数据库·mysql
浪客灿心5 小时前
项目篇:模块设计与实现
数据库·c++
流星白龙7 小时前
【MySQL高阶】26.事务(1)
数据库·mysql
三十..7 小时前
Redis 核心原理与高可用架构实践
运维·数据库·redis
这个DBA有点耶8 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构
用户3074596982078 小时前
EXPLAIN 执行计划 完全精通指南
mysql
努力努力再努力wz8 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表