美文网首页
index pushdown

index pushdown

作者: 爱钓鱼的码农 | 来源:发表于2020-11-02 08:50 被阅读0次

    表结构

    CREATE TABLE `tuser` (
      `id` int(11) NOT NULL,
      `id_card` varchar(32) DEFAULT NULL,
      `name` varchar(32) DEFAULT NULL,
      `age` int(11) DEFAULT NULL,
      `ismale` tinyint(1) DEFAULT NULL,
      PRIMARY KEY (`id`),
      KEY `id_card` (`id_card`),
      KEY `name_age` (`name`,`age`)
    ) ENGINE=InnoDB
    

    索引覆盖

    如果执行的语句是 select ID from T where k between 3 and 5,这时只需要查 ID 的值,而 ID 的值已经在 k 索引树上了,因此可以直接提供查询结果,不需要回表。  
    也就是说,在这个查询里面,索引 k 已经“覆盖了”我们的查询需求,我们称为覆盖索引。
    

    索引下推

    
    mysql> select * from tuser where name like '张%' and age=10 and ismale=1;
    
    这个语句在搜索索引树的时候,只能用 “张”,找到第一个满足条件的记录 ID3。
    当然,这还不错,总比全表扫描要好。  
    在 MySQL 5.6 之前,只能从 ID3 开始一个个回表。到主键索引上找出数据行,再对比字段值。
    而 MySQL 5.6 引入的索引下推优化(index condition pushdown), 可以在索引遍历过程中,对索引中包含的字段先做判断,直接过滤掉不满足条件的记录,减少回表次数。
    
    

    相关文章

      网友评论

          本文标题:index pushdown

          本文链接:https://www.haomeiwen.com/subject/nwppvktx.html