清华大佬整理的Mysql面试技术名词(建议收藏)

2 篇文章 0 订阅
2 篇文章 0 订阅
本文介绍了MySQL面试中常见的技术名词,包括回表、覆盖索引、最左前缀匹配和索引下推。回表是指通过普通索引找到主键值后再去主键索引获取完整数据的过程。覆盖索引则允许在索引树中直接获取所需列,避免回表。最左前缀匹配强调组合索引时,最左边列未命中则索引无效。索引下推(ICP)在MySQL 5.6及以上版本中可以减少回表次数,提高查询效率。
摘要由CSDN通过智能技术生成

 

面试的技术名词

面试一般会遇到一些名词,其实可能自己都知道其中的道理,但是因为没了解过,当时心里就一句WC,然后弱弱答一句:不好意思这个我只是听过,具体还没了解过;

  • 回表
  • 覆盖索引
  • 最左前缀匹配
  • 索引下推

1、回表

所谓的回表就是因为普通索引的叶子节点中存储的不是行数据而是主键的值,然后通过主键值到主键索引树中的叶子节点获取具体的值;

          

首先表中有5条基本数据;

          

下图为主键索引树(B+Tree)的简化模型:

       

下图为回表的简化流程图:

在普通索引树中获取主键id的值,然后再到主键索引树中回去主键索引对应的行数据,此过程称之为回表;

        

2、索引覆盖

所谓的索引覆盖就是:只需要在一棵索引树上就能获取SQL所需的所有列数据,无需回表,速度更快。

       

 

 上图为age的索引树 如果你只需要获取id 和 age 在此树中已经可以直接获取, 没必要进行回表操作;

            

 

3、最左前缀匹配

当建立组合索引时,如果按照建立索引的顺序如果最左列没有命中,则组合索引失效;

            

 

当content没有命中索引时,age的索引失效;

            

 

 

4、  索引下推

l  索引下推(index condition pushdown )简称ICP,在Mysql5.6的版本上推出,用于优化查询

 

l  索引下推在非主键索引上的优化,可以有效减少回表的次数,大大提升了查询的效率。

在employee表中建立组合索引lastName和age

            

            

            select * from employee where lastName like 'lu%' and age = 67;

Mysql5.6以前:

    会忽略age这个字段,直接通过name进行查询,在(name,age)这课树上查找到了两个结果,id分别为2,6,然后拿着取到的id值一次次的回表查询,因此这个过程需要回表两次

Mysql5.6以及5.6以后版本:

    并没有忽略age这个字段,而是在索引内部就判断了age是否等于20,对于不等于20的记录直接跳过,因此在(name,age)这棵索引树中只匹配到了id为6一个记录,此时拿着这个id去主键索引树中回表查询全部数据,这个过程只需要回表一次

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值