mysql最佳左_mysql索引最左匹配原则的理解?

表结构如下

CREATE TABLE `student` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(255) DEFAULT NULL,

`cid` int(11) DEFAULT NULL,

PRIMARY KEY (`id`),

KEY `name_cid_INX` (`name`,`cid`),

) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8

首先我们需要知道InnoDB引擎中索引的结构,与MyISAM不同的一点,InnoDB中辅助索引的数据域存储的是主键的值而不是地址,也就是说,正常情况下通过辅助索引查询数据时,先从辅助索引拿到主键值,再通过主键值走一次主索引拿数据(辅助索引搜索需要检索两遍索引)。

既然辅助索引中数据域存储了主键的值,那么我们也可以理解成每个辅助索引都包含了主键列。

这意味着,name_cid_INX索引实际包含了id,name,cid字段,也就是包含了该表中的所有字段。

当我们执行SELECT * FROM student WHERE cid=1;的时候,mysql会判断出索引name_cid_INX中包含了需要查询的所有字段,也就是覆盖索引。这个时候mysql会认为走一次name_cid_INX是最好的选择(实际情况并不一定是最好的)。

对于EXPLAIN SELECT * FROM student WHERE cid=1;的结果

我的理解是mysql发现name_cid_INX中包含了需要查询的所有字段,所以认为读索引会比读全文来的快(因为索引文件总是要小于数据文件的),于是type的值为index,key的值为name_cid_INX也就没什么疑问了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值