索引可以让查询锁定更少的行.如果你的查询从不访问哪些不需要的行,那么就会锁定更少的行,从两方面来看这对性能都有好处.
Innodb只有在访问行的时候才会对其加锁,而索引能够减少Innodb访问的行数,从而减少锁的数量.但这只有当Innodb在存储引擎层能够过滤掉索引不需要的行的时候才有效果,
如果索引无法过滤无效的行,那么在Innodb检索到数据并返回给服务层以后,mysql服务器才能应用到where子句.这时候已经无法避免锁定行了,innodb已经锁定这些行了,到适当的时候才会释放,
在mysql5.1以及更新版本的时候,innodb可以在服务器端过滤掉后就释放锁,但是在早期的mysql版本中,Innodb只有在事务提交后才能释放锁
看下面的例子
~~~
set autocommit = 0 ;
begin;
select actor_id from sakila.actor where actor_id < 5 and actor_id <> 1 for update;
~~~
![](https://box.kancloud.cn/b13cee526a474de61df9849bb23cd534_675x310.png)
底层的存储引擎的操作是"从索引头开始获取满足条件actor_id < 5"的记录,服务器并没有告诉Innodb可以过滤第一行的where条件,注意到explain的extra出现了Using where,这表示mysql服务器将存储引擎返回行以后再应用where过滤条件
下面的第二个查询就能证明第一行确实被锁定,尽管第一个查询的结果中并没有这个第一行,保持第一个连接打开,然后开启第二个连接并执行如下的查询
![](https://box.kancloud.cn/deef840b4a7abaf27a1bc3ee710ea867_586x69.png)
这个查询将会挂起,直到第一个事务释放第1行的锁,这个行为对于基于语句的复制的正常运行来说是必要的.(尽管在理论上使用基于行的日志模式,在某些是事务隔离级别下,服务器不再需要锁定行,但是实际上经常发现无法实现这种预期的行为.知道mysql5.6.3版本,在read-commit隔离级别和基于行的日志模式下,这个例子还是会导致锁)
就像这个例子显示的,即使使用了索引,Innodb也可能锁住一些不需要的数据.如果不能使用索引查找和锁定行的话问题可能会很糟糕,mysql会做全表扫描并锁住所有的行,而不管是不是需要的
关于Innodb,索引和锁有一些很少有人知道的细节,Innodb在二级索引上使用共享(读)锁,但访问主键索引需要排他(写)锁,这消除了使用索引覆盖的可能性,并且使得select for update 比 lock in share mode或非锁定查询要慢很多
- 书列表
- 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与数据类型优化
- 选择优化的数据类型
- 日期和时间类型
- 标识列
- 特殊类型数据
- 表设计中的缺陷
- 范式
- 计数器表
- 第五章 创建高性能索引
- 索引基础
- 索引类型
- 索引的优点
- 高性能索引策略
- 选择合适的索引列顺序
- 聚簇索引
- 顺序的主键什么时候会造成更坏的后果
- 覆盖索引
- 使用索引扫描来做排序
- 压缩索引
- 冗余和重复索引
- 索引和锁
- 支持多种过滤条件
- 什么是范围条件
- 优化排序
- 维护索引和表
- 表损坏
- 减少索引和数据的碎片
- 第六章 查询性能优化
- 扫描的行数和访问类型
- 重构查询方式
- 查询执行的基础
- 重构-改善既有代码设计
- 第一章-重构
- 什么是重构
- 第一个案列
- 重构第一步
- 王垠博客
- 多态取代价格相关逻辑