MySQL中MVCC有哪些用法

本文主要给大家简单讲讲MySQL中MVCC有哪些用法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL中MVCC有哪些用法这篇文章可以给大家带来一些实际帮助。

网站建设哪家好,找成都创新互联!专注于网页设计、网站建设、微信开发、成都小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了广南免费建站欢迎大家使用!

MVCC(多版本并发控制)

作用:很多情况下可以避免加锁操作,降低开销。

InnoDB下的MVCC

通过在每行记录后面保存两个隐藏的列来实现,行的创建时间、行的过期时间(删除时间)。这里的时间指的是系统版本号,每开始一个新的事物,系统版本号都会自增。事物开始时刻的系统版本号会作为事物的版本号,用来和查询到的每行记录的版本号进行比较。

REPEATABLE READ隔离级别下MVCC的具体操作

SELECT

InnoDB 只查找版本早于当前事物版本的数据行(行的系统版本号 <= 事物的系统版本号),这样可以确保事物读取的行,要么是在事物开始前已经存在的,要么是事物自身插入或者修改过的。(也就是和其它事物是隔离的)

行的删除版本要么未定义,要么大于当前事物版本号。这样可以确保事物读取到的行,在事物开始之前未被删除。

符合上面两个条件的记录才能返回做完查询结果。

INSERT

InnoDB 为新插入的每一行保存当前系统版本号作为行版本号。

UPDATE

InnoDB 为插入一行新记录,保存当前系统版本号作为行版本号,同时保存当前系统版本号到原来的行作为行删除标识。

DELETE

InnoDB 为删除的每一行保存当前系统版本号作为删除标识。

MySQL中MVCC有哪些用法就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。


标题名称:MySQL中MVCC有哪些用法
URL标题:http://bzwzjz.com/article/jcojgd.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: app网站建设 成都网站制作 成都网站制作 广安网站设计 定制网站设计 成都企业网站设计 成都网站建设公司 网站建设开发 网站建设公司 成都网站设计 成都网站设计制作公司 专业网站设计 企业网站制作 网站设计制作 成都网站建设 成都网站建设 重庆网站建设 成都网站设计 攀枝花网站设计 重庆企业网站建设 网站设计 重庆企业网站建设