【MySQL面试题】建立a,b,c三个字段的联合索引,判断下列语句是否使用到索引?用到了哪些索引?(通过explain的key_len来判断)

建立a,b,c三个字段的联合索引,判断下列语句是否使用到索引?用到了哪些索引?

创建一个test表,创建表的语句如下:

CREATE TABLE `test` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `a` int(255) DEFAULT NULL,
  `b` int(255) DEFAULT NULL,
  `c` int(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `index_abc` (`a`,`b`,`c`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

联合索引:index_abc (a,b,c)
a、b、c三个字段类型均为int且允许为空。

问题:下列语句是否使用到索引?用到了哪些索引?

  1. select * from test where a=1 and b>1 order by c;
    在这里插入图片描述
    如图:从key这一列的值为index_abc可以得出MySQL优化器使用到了联合索引index_abc,我们再来看一下key_len这一列,key_len就是索引长度,这里的长度为5,我们知道int类型的长度是4,又允许为空,所以key_len=4+1,就是这里的长度5了。

    答:语句使用到了索引,结合最左匹配原则,再加上key_len的长度,综合分析得出:使用的是a字段的单列索引。
    为什么呢?
    因为MySQL最左匹配原则会一直向右匹配,直到遇到范围查询就会停止匹配,这里条件是where a=1 and b>1 order by c,所以匹配完a字段,匹配b字段是遇到了范围查询就停止匹配了,所以字段b和c都没有使用到索引。

  2. select * from test where a=1 and b=2 order by c;
    在这里插入图片描述
    如图:从key这一列的值为index_abc可以得出MySQL优化器使用到了联合索引index_abc,我们再来看一下key_len这一列,这里的长度为10,从上面分析我们知道int类型且允许为空时的长度是5,而我们的查询条件是where a=1 and b=2 order by c,所以用到了index_ab索引。

    答:语句使用到了索引,结合最左匹配原则,再加上key_len的长度,综合分析得出:使用的是ab字段的联合索引。

  3. select * from test group by c;
    在这里插入图片描述
    如图:从key这一列的值为index_abc可以得出MySQL优化器使用到了联合索引index_abc,我们再来看一下key_len这一列,这里的长度为15,从上面分析我们知道int类型且允许为空时的长度是5,index_abc联合索引的最大可能长度也是15,所以是使用到了index_abc联合索引。

    答:语句使用到了索引,使用的是index_abc联合索引。

补充内容:
key_len表示使用的索引长度,key_len可以衡量索引的好坏,key_len越小 索引效果越好。常见的列类型长度计算:

列类型是否为空长度key_len备注
tinyint允许Null1key_len = 1+1允许NULL,key_len长度加1
tinyint不允许Null1key_len = 1不允许NULL
int允许Null4key_len = 4+1允许NULL,key_len长度加1
int不允许Null4key_len = 4不允许NULL
bigint允许Null8key_len = 8+1允许NULL,key_len长度加1
bigint不允许Null8key_len = 8不允许NULL
char(1)允许Nullutf8mb4=4,utf8=3,gbk=2key_len = 1*3 + 1允许NULL,字符集utf8,key_len长度加1
char(1)不允许Nullutf8mb4=4,utf8=3,gbk=2key_len = 1*3不允许NULL,字符集utf8
varchar(10)允许Nullutf8mb4=4,utf8=3,gbk=2key_len = 10*3 + 2 + 1动态列类型,key_len长度加2,允许NULL,key_len长度加1
varchar(10)不允许Nullutf8mb4=4,utf8=3,gbk=2key_len = 10*3 + 2动态列类型,key_len长度加2
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MySQL语句面试是指在MySQL数据库相关的面试中经常会被问到的问。以下是一些常见的MySQL语句面试及答案: 1. NOW()和CURRENT_DATE()有什么区别? - NOW()函数返回的是当前日期和时间,包括年、月、日、时、分、秒。 - CURRENT_DATE()函数返回的是当前日期,只包括年、月、日。 2. 什么是索引? - 索引是一种数据结构,用于加快数据库查询的速度。它可以帮助数据库系统快速定位到符合查询条件的记录。 3. 什么是主键和外键? - 主键是用于唯一标识表中每条记录的字段,每个表只能有一个主键。 - 外键是一个表中的字段,它与另一个表的主键形成关联关系,用于保持数据的完整性。 4. 如何查询表中前N条记录? - 使用LIMIT子句可以指定查询结果的行数。例如,使用LIMIT 5可以查询表中的前5条记录。 5. 如何删除表中的重复记录? - 可以使用DELETE和子查询来删除表中的重复记录。首先,使用子查询找出重复的记录,然后使用DELETE语句删除这些记录。 6. 如何对表中的数据进行排序? - 使用ORDER BY子句可以对查询结果按照某个字段进行排序。例如,使用ORDER BY column_name可以按照column_name字段进行升序排序。 这些是一些常见的MySQL语句面试及答案,希望对你有帮助。如果你有更多问或需要了解更多面试,可以参考MySQL面试手册。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [110道 MySQL面试及答案 (持续更新)](https://blog.csdn.net/u012889902/article/details/121677978)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值