mysql索引技术名词1-5


目录

  • 索引技术名词
    • 1.回表
    • 2.覆盖索引
    • 3.最左匹配原则
    • 4.索引下推
    • 5.谓词下推
【mysql索引技术名词1-5】
索引技术名词 1.回表
注意: 1.如果依靠主键查询,叶子结点直接存储数据----主键B+树 2.如果依靠其他健查询查询,叶子结点存储主键值,再通过主键值查询数据。通过主键值查询数据的过程叫做回表----普通B+树字段查找主键,再到主键B+树查询数据

2.覆盖索引
1:select * from table1 where name='zhangsan' 2:select id from table1 where name='zhangsan'第一种必须进行回表查询其他字段数据 第二种,其他健的B+树叶子结点已经存储id值,直接返回,不需要进行回表操作。叫做覆盖索引

3.最左匹配原则
id,name,age,gender 给(name,age)创建了组合索引1:select * from table1 where name='zhangsan' 2:select * from table1 where name='zhangsan' and age=10 3:select * from table1 where age=10 4:select * from table1 where age=10 and name='zhangsan'第1,2,4种用到了组合索引,最左原则。必须先查左边的name,再查右边的age 第4中因为mysql架构在优化器的时候内部会重构执行流程

4.索引下推
(name,age)组合索引,最左原则 正常情况下: 1.先根据name列从存储引擎中把符合规则的数据拉取到mysql的server曾 2.再server层按照age进行数据过滤索引下推情况下: 1.直接从存储引擎拉取数据的时候直接按照name和age做判断,将符合的结果返回给mysql的server层

5.谓词下推
select t1.name,t2.name from t1 join t2 on t1.id=t2.id执行方式: 1:把所有的字段先做表关联,然后再从关联好的表中选择需要的4个字段 2:先把两张表需要的4个字段取出,然后再做表关联结论:很明显使用第二种,减少不必要的数据量

    推荐阅读