覆盖索引是一种避免回表查询的优化策略: 只需要在一棵索引树上就能获取SQL所需的所有列数据,无需回表,速度更快。
具体的实现方式:
-
将被查询的字段建立普通索引或者联合索引,这样的话就可以直接返回索引中的的数据,不需要再通过聚集索引去定位行记录,避免了回表的情况发生。
EXPLAIN SELECT user_name,user_age,user_level FROM users WHERE user_name = 'tom' AND user_age = 17;
覆盖索引的定义与注意事项:
-
如果一个索引包含了 所有需要查询的字段的值 (不需要回表),这个索引就是覆盖索引。
-
MySQL只能使用B+Tree索引做覆盖索引 (因为只有B+树能存储索引列值)
-
在explain的Extra列, 如果出现 **
Using index
表示 使用到了覆盖索引 , 所取的数据完全在索引中就能拿到
知识来源:马士兵教育