作为程序员一定要保持良好的睡眠,才能好编程

explain 中key_len的作用及计算规则

发布时间:2019-04-03

explain 中key_len的作用

key_len越小 索引效果越好

key_len的长度是如何计算的?

name的字段类型是varchar(20),字符编码是utf8,一个字符占用3个字节,那么key_len应该是 20*3=60。

key_len.png


key_len的长度计算公式:

varchr(10)变长字段且允许NULL    =  10 * ( character set:utf8=3,gbk=2,latin1=1)+1(NULL)+2(变长字段)

varchr(10)变长字段且不允许NULL =  10 *( character set:utf8=3,gbk=2,latin1=1)+2(变长字段)


char(10)固定字段且允许NULL        =  10 * ( character set:utf8=3,gbk=2,latin1=1)+1(NULL)

char(10)固定字段且不允许NULL        =  10 * ( character set:utf8=3,gbk=2,latin1=1)


bigint的长度是8bytes

int key_len长度是4 ,typeint的长度是1


smallint 长度是2   middleint长度是3




在这里 key_len 大小的计算规则是:


a、一般地,key_len 等于索引列类型字节长度,例如int类型为4-bytes,bigint为8 bytes;


b、如果是字符串类型,还需要同时考虑字符集因素,例如:CHAR(30) UTF8则key_len至少是90 bytes;


c、若该列类型定义时允许NULL,其key_len还需要再加 1 bytes;


d、若该列类型为变长类型,例如 VARCHAR(TEXT\BLOB不允许整列创建索引,如果创建部分索引,也被视为动态列类型),其key_len还需要再加 2 bytes


举例说明

 

例如,有个联合索引 idx1(c1, c2, c3),3个列均是INT NOT NULL,那么下面的这个SQL执行计划中,key_len的值是8而不是12:


SELECT…WHERE c1=? AND c2=? ORDER BY c1;


这句话的意思是: 没有使用完全索引



通过这个案例,就可以知道 有没有完全使用索引。