java八股文面试[数据库]——索引覆盖

覆盖索引是一种避免回表查询的优化策略: 只需要在一棵索引树上就能获取SQL所需的所有列数据,无需回表,速度更快。

具体的实现方式:

  • 将被查询的字段建立普通索引或者联合索引,这样的话就可以直接返回索引中的的数据,不需要再通过聚集索引去定位行记录,避免了回表的情况发生。

EXPLAIN SELECT user_name,user_age,user_level FROM users 
WHERE user_name = 'tom' AND user_age = 17;

java八股文面试[数据库]——索引覆盖_第1张图片

覆盖索引的定义与注意事项:

  • 如果一个索引包含了 所有需要查询的字段的值 (不需要回表),这个索引就是覆盖索引。

  • MySQL只能使用B+Tree索引做覆盖索引 (因为只有B+树能存储索引列值)

  • 在explain的Extra列, 如果出现 **Using index 表示 使用到了覆盖索引 , 所取的数据完全在索引中就能拿到

知识来源:马士兵教育

你可能感兴趣的:(java八股文【数据库】,面试,数据库,职场和发展)