博客
关于我
[MySQL] MVCC 多版本并发控制实现的事务
阅读量:661 次
发布时间:2019-03-15

本文共 745 字,大约阅读时间需要 2 分钟。

InnoDB引擎中的MVCC(Multi-Version Concurrency Control)是一种用于处理多版本并发控制的高级事务管理机制。通过为每行记录维护多个版本号,MVCC能够在读写频繁的高并发场景下提供较高的性能,同时保证事务的一致性和隔离性。

MVCC工作机制基于每个事务的版本号来维护行记录的可见性和一致性。当事务开始时,系统会为当前用户生成一个唯一的版本号,这个版本号会被同步到所有被修改的行记录中。通过在每行记录中添加两个隐藏字段:"创建版本号"和"删除版本号",MVCC可以精确控制数据的可见性:

  • 在插入新数据时,系统会将当前事务的版本号写入"创建版本号"字段。
  • 在更新操作时,系统会将当前事务的版本号写入"删除版本号"字段,并且将旧版本号设置为当前事务的版本号。
  • 在删除操作时,系统只需要将"删除版本号"字段设置为当前事务的版本号,无需修改其他数据。
  • 在查询操作时,系统会根据事务版本号来筛选数据:创建版本号必须小于等于当前事务版本号,且删除版本号必须存在或小于当前版本号。这保证了查询得到的数据要么是当前或之前版本的数据。

这种设计可以避免传统锁机制对并发操作的阻塞,显著提升了系统的并发处理能力。然而,这也意味着额外的存储开销(隐藏字段的使用)以及在特定场景下可能需要加锁(如在SERIALIZABLE隔离级别下)的问题。

MVCC机制适用于REPEATABLE READ和READ COMMITTED隔离级别。在READ UNCOMMITED隔离级别下,MVCC会直接读取最新的数据版本,而在SERIALIZABLE隔离级别下,系统会对读取的行加锁,确保数据的一致性。这种灵活的并发控制机制使得InnoDB在高并发场景下能够在性能和一致性之间找到较好的平衡。

转载地址:http://tqnmz.baihongyu.com/

你可能感兴趣的文章
Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
查看>>
oracle 去重
查看>>
oracle 可传输的表空间:rman
查看>>
Oracle 启动监听命令
查看>>
Oracle 启动阶段 OPEN
查看>>
Oracle 在Drop表时的Cascade Constraints
查看>>
Oracle 在Sqlplus 执行sql脚本文件。
查看>>
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 导出sql数据库表结构,使用sql developer 导出Oracle数据库中的表结构
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
ORACLE 异常错误处理
查看>>