[MySQL] MVCC多版本并发控制实现的事务


本文摘自PHP中文网,作者little bottle,侵删。

Multi-Version Concurrency Control 多版本并发控制,MVCC 是一种并发控制的方法,一般在数据库管理系统中,实现对数据库的并发访问;在编程语言中实现事务内存。

1.没有一个统一的实现标准,实现了非阻塞的读操作,写操作也只锁定必要的行
2.通过保存数据在某个时间点的快照实现的
3.典型的有乐观并发控制和悲观并发控制
4.innodb的mvcc是每次事务都有递增的版本号,通过在每行记录的后面添加两列隐藏字段,两列分别是是创建版本号和删除版本号,存储操作它事务的版本号
5.在事务中增删改查就是对两列版本号字段进行操作

insert 为新插入的每一行保存当前事务版本号到 行创建版本号字段
update 插入一行新的保存当前事务创建版本号,修改原行数据的删除版本号为本次事务的版本号
delete 修改行的删除版本号字段为本次事务的版本号
select 查询 创建版本号字段 小于等于当前事务版本的数据 确保该记录是本次之前就存在的或本次事务新插的
查询 删除版本号字段 不存在或者大于当前版本的数据 确保该记录在本次事务之前没删除

6.这样的设计就不需要加锁了,读和操作性能好,但是需要额外的存储空间
7.mvcc只在REPEATABLE READ和READ COMMITED两个隔离下工作;READ UNCOMMITED总是读取最新数据;SERIALIZABLE对读取的行都加锁

【推荐课程:mysql视频教程】

以上就是[MySQL] MVCC多版本并发控制实现的事务的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

图文详解navicat中如何使用命令创建数据库和表

如何修改mysql中的允许主机访问权限得解析

mysql中如何同时查询两个数据库中的数据

mysql如何查询时间段

mysql 5.7中的关键字与保留字详解

教你如何查看mysql配置文件路径及相关配置

mysql判断列是否存在

关于mysql的基础知识详解

mysql逻辑删除如何恢复

[mysql] mvcc多版本并发控制实现的事务

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...