什么是覆盖索引?如何利用索引进行SQL语句优化?

为什么80%的码农都做不了架构师?>>>   hot3.png

如果你不知道什么是覆盖索引,那么SQL性能优化便无从谈起!

什么是覆盖索引?如何利用索引进行SQL语句优化?

表结构

150多万的数据,这么一个简单的语句:

慢查询日志里居然很多用了1秒的,Explain的结果是:

从Explain的结果可以看出,查询已经使用了索引,但为什么还这么慢?

分析:首先,该语句ORDER BY 使用了Using filesort文件排序,查询效率低;其次,查询字段不在索引上,没有使用覆盖索引,需要通过索引回表查询;也有数据分布的原因。

知道了原因,那么问题就好解决了。

解决方案:由于只需查询uid字段,添加一个联合索引便可以避免回表和文件排序,利用覆盖索引提升查询速度,同时利用索引完成排序。

覆盖索引:SQL只需要通过索引就可以返回查询所需要的数据,而不必通过二级索引查到主键之后再去查询数据。

我们再Explain看一次:

Extra信息已经有'Using Index',表示已经使用了覆盖索引。经过索引优化之后,线上的查询基本不超过0.001秒。

 

转载于:https://my.oschina.net/90888/blog/1582173

你可能感兴趣的:(什么是覆盖索引?如何利用索引进行SQL语句优化?)