什么是覆盖索引?如何利用索引进行SQL语句优化?
2017-11-30 00:00
756 查看
如果你不知道什么是覆盖索引,那么SQL性能优化便无从谈起!
什么是覆盖索引?如何利用索引进行SQL语句优化?
![](https://static.oschina.net/uploads/space/2017/1130/152719_tmaE_2927759.png)
150多万的数据,这么一个简单的语句:
![](https://static.oschina.net/uploads/space/2017/1130/152745_ExqX_2927759.jpg)
慢查询日志里居然很多用了1秒的,Explain的结果是:
![](https://static.oschina.net/uploads/space/2017/1130/152805_pdZo_2927759.jpg)
从Explain的结果可以看出,查询已经使用了索引,但为什么还这么慢?
分析:首先,该语句ORDER BY 使用了Using filesort文件排序,查询效率低;其次,查询字段不在索引上,没有使用覆盖索引,需要通过索引回表查询;也有数据分布的原因。
知道了原因,那么问题就好解决了。
解决方案:由于只需查询uid字段,添加一个联合索引便可以避免回表和文件排序,利用覆盖索引提升查询速度,同时利用索引完成排序。
![](https://static.oschina.net/uploads/space/2017/1130/152826_Fsxe_2927759.jpg)
覆盖索引:SQL只需要通过索引就可以返回查询所需要的数据,而不必通过二级索引查到主键之后再去查询数据。
我们再Explain看一次:
![](https://static.oschina.net/uploads/space/2017/1130/152850_EHwB_2927759.jpg)
Extra信息已经有'Using Index',表示已经使用了覆盖索引。经过索引优化之后,线上的查询基本不超过0.001秒。
什么是覆盖索引?如何利用索引进行SQL语句优化?
表结构
![](https://static.oschina.net/uploads/space/2017/1130/152719_tmaE_2927759.png)
150多万的数据,这么一个简单的语句:
![](https://static.oschina.net/uploads/space/2017/1130/152745_ExqX_2927759.jpg)
慢查询日志里居然很多用了1秒的,Explain的结果是:
![](https://static.oschina.net/uploads/space/2017/1130/152805_pdZo_2927759.jpg)
从Explain的结果可以看出,查询已经使用了索引,但为什么还这么慢?
分析:首先,该语句ORDER BY 使用了Using filesort文件排序,查询效率低;其次,查询字段不在索引上,没有使用覆盖索引,需要通过索引回表查询;也有数据分布的原因。
知道了原因,那么问题就好解决了。
解决方案:由于只需查询uid字段,添加一个联合索引便可以避免回表和文件排序,利用覆盖索引提升查询速度,同时利用索引完成排序。
![](https://static.oschina.net/uploads/space/2017/1130/152826_Fsxe_2927759.jpg)
覆盖索引:SQL只需要通过索引就可以返回查询所需要的数据,而不必通过二级索引查到主键之后再去查询数据。
我们再Explain看一次:
![](https://static.oschina.net/uploads/space/2017/1130/152850_EHwB_2927759.jpg)
Extra信息已经有'Using Index',表示已经使用了覆盖索引。经过索引优化之后,线上的查询基本不超过0.001秒。
相关文章推荐
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- SQL 语句优化—— (二) 索引的利用
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何建索引以及利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句 【转载】
- MySQL如何利用索引优化ORDER BY排序语句
- SQL优化技术分析-3:SQL语句索引的利用
- MySQL如何建索引以及利用索引优化ORDER BY排序语句
- MySQL如何利用索引优化ORDER BY排序语句
- 【MySql性能优化二】利用explain进行查询和分析sql语句
- MySQL如何利用索引优化ORDER BY排序语句
- 如何对于几百行SQL语句进行优化?
- MySQL如何利用索引优化ORDER BY排序语句