mysql的大多数事务型存储引擎实现的都不是简单的行级锁,基于提升并发性能的考虑.他们一般都同时实现了多版本并发控制(MVCC)
不仅是mysql,包括oracle,pgsql其他数据可以也实现了mvcc,但是实现的机制不同,没有统一实现标准
可以认为MVCC是行级锁的一个变种,但是很多情况下避免了加锁操作,因此开销更低.虽然实现机制各有不同,但大都实现了非阻塞的读操作,写操作也只锁定必要的行
MVCC的实现,是通过保存数据在某个时间点的快照来实现的.也就是说,不管需要执行多长时间,每个事务看到的数据都是一致的.根据事务开始时间不同,每个事务对同一张表,同一时刻看到的数据可能是不一样的.
不同的存储引擎的MVCC实现的不同,典型的有乐观并发控制和悲观并发控制
---
innodb的MVCC是通过在每行记录的后面保存两个隐藏的列来实现的.这2个列,一个保存了行的创建时间,一个保存了行的过期时间(或者删除时间).当然存储的并不是实际的时间值,而是系统的版本号.每开始一个新的事务,系统版本号都会自动递增.
事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号进行比较.下面看一下REPEATABLE READ隔离级别下,MVCC具体如何操作
![](https://box.kancloud.cn/a8c267ce6039010d8d3111226ad95887_689x432.png)
保存这2个额外的系统版本号,使大多数读操作都可以不用加锁.这样设计使得读数据操作很简单,性能很好,并且也能保证只会读取到符合标准的行
不足之处是每行记录都需要额外的空间,需要做更多的检查,以及一些额外的维护工作
MVCC只在REPEATABLE READ 和 READ COMMITTED 两个隔离级别下的工作
其他隔离级别都和MVCC不兼容,因为READ UNCOMMITTED总是读取最新的数据行,而不是符合当前事务版本的数据行,而SERIALIZABLE会对所有读取的行都要加锁
- 书列表
- laravel框架关键技术
- 第一章 组件化开发与composer使用
- 简介
- composer
- 添加路由组件
- 添加控制器模块
- 添加模型组件
- 添加视图组件
- 第三章 laravel框架中常用的php语法
- 匿名函数
- 文件包含
- 魔术方法
- 魔术常量
- 反射
- 后期静态绑定
- traits
- 第四章 laravel框架中使用的HTTP协议基础
- HTTP协议
- 数据库
- 数据迁移
- 第六章 laravel框架中的设计模式
- IOC模式
- php核心技术与最佳实践
- 第一章面向对象核心
- 反射
- 简单ORM
- 异常和错误
- 接口
- 第二章,面向对象设计
- 设计原则
- 单一职责
- 接口隔离
- 开放封闭
- 替换原则
- 依赖倒置
- linux是怎么写的呢?
- 第三章 正则表达
- 认识正则
- 第四章 php网络技术应用
- HTTP协议详解
- php和http相关函数
- 垃圾信息防御措施
- 现代操作系统
- 引论
- sql必知必会
- 限制结果
- 按位置排序
- where求职顺序
- IN操作符
- like
- 函数
- group by
- 组合查询
- 插入检索出的数据
- 视图
- 高性能mysql
- 第一章节 mysql架构与历史
- mysql架构逻辑图
- 连接与管理
- 优化与运行
- 读写锁
- 锁粒度
- 表锁(table lock)
- 行级锁(row lock)
- ACID
- 隔离级别
- 死锁
- 隐式和显式锁定
- 多版本并发控制
- Innodb概览
- 第四章节 Schema与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑