您的位置:首页 > 数据库

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

2017-11-30 00:00 756 查看
如果你不知道什么是覆盖索引,那么SQL性能优化便无从谈起!

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

表结构



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



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



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

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

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

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



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

我们再Explain看一次:



Extra信息已经有'Using Index',表示已经使用了覆盖索引。经过索引优化之后,线上的查询基本不超过0.001秒。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: