解读EXPLAIN执行计划中的key_len
浏览:1026次 出处信息
导读
EXPLAIN中的key_len一列表示什么意思,该如何解读?
EXPLAIN执行计划中有一列 key_len 用于表示本次查询中,所选择的索引长度有多少字节,通常我们可借此判断联合索引有多少列被选择了。
在这里 key_len 大小的计算规则是:
一般地,key_len 等于索引列类型字节长度,例如int类型为4-bytes,bigint为8-bytes;
如果是字符串类型,还需要同时考虑字符集因素,例如:CHAR(30) UTF8则key_len至少是90-bytes;
若该列类型定义时允许NULL,其key_len还需要再加 1-bytes;
若该列类型为变长类型,例如 VARCHAR(TEXT\BLOB不允许整列创建索引,如果创建部分索引,也被视为动态列类型),其key_len还需要再加 2-bytes;
综上,看下面几个例子:
列类型 | key_len | 备注 |
---|---|---|
id int | key_len = 4+1 = 5 | 允许NULL,加1-byte |
id int not null | key_len = 4 | 不允许NULL |
user char(30) utf8 | key_len = 30*3+1 | 允许NULL |
user varchar(30) not null utf8 | key_len = 30*3+2 | 动态列类型,加2-bytes |
user varchar(30) utf8 | key_len = 30*3+2+1 | 动态列类型,加2-bytes;允许NULL,再加1-byte |
detail text(10) utf8 | key_len = 30*3+2+1 | TEXT列截取部分,被视为动态列类型,加2-bytes;且允许NULL |
备注,key_len 只指示了WHERE中用于条件过滤时被选中的索引列,是不包含 ORDER BY/GROUP BY 这部分被选中的索引列。
例如,有个联合索引 idx1(c1, c2, c3),3个列均是INT NOT NULL,那么下面的这个SQL执行计划中,key_len的值是8而不是12:
SELECT…WHERE c1=? AND c2=? ORDER BY c1;
关于MySQL的方方面面大家想了解什么,可以直接留言回复,我会从中选择一些热门话题进行分享。 同时希望大家多多转发,多一些阅读量是老叶继续努力分享的绝佳助力,谢谢大家 :)
建议继续学习:
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:清官谈mysql中utf8和utf8mb4区别
后一篇:MySQL索引之聚集索引 >>
文章信息
- 作者:叶金荣 来源: iMySQL
- 标签: EXPLAIN key_len
- 发布时间:2015-10-26 22:21:59
建议继续学习
近3天十大热文
-
[58] memory prefetch浅析
-
[54] 转载:cassandra读写性能原理分析
-
[47] MySQL半同步存在的问题
-
[46] 深入浅出cassandra 4 数据一致性问
-
[41] javascript插入样式
-
[40] 《web前端最佳实践》—高维护性css
-
[39] 获取Dom元素的X/Y坐标
-
[37] MySQL vs NoSQL 效率与成本之争
-
[35] 不是书评 :《我是一只IT小小鸟》
-
[34] 基本排序算法的PHP实现