学习mysql的explain中key_len的作用及计算规则
explain中key_len的作用
key_len越小 索引效果越好
key_len的长度是如何计算的?
name的字段类型是varchar(20),字符编码是utf8,一个字符占用3个字节,那么key_len应该是 20*3=60。
字段类型 | key_len | 备注 |
---|---|---|
int | 4+1=5 | 允许为null,加1-bite |
id not null | 4 | 不允许为null |
char(30) utf8 | 30*3+1 | 允许null |
varchar(30) not null utf8 | 30*3+2 | 动态列类型,加2-bytes,不允许null |
varchar(30) utf8 | 30*3+2+1 | 动态列类型,加2-bytes;允许null,再加1-byte |
text(10) | 30*3+2+1 | text列截取部分,被视为动态列类型,加2-bytes,且允许null |
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