我们可以讲组合索引想成书的一级目录、二级目录、三级目录,如index(a,b,c),相当于a是一级目录,b是一级目录下的二级目录,c是二级目录下的三级目录。要使用某一目录,必须先使用其上级目录,除了一级目录除外。
所以
where a=1 and c=1只使用了一级目录,c在三级目录,没有使用二级目录,那么三级目录就没法使用
where a=1 and b=1只使用了一级目录、二级目录。
于是第二条查询的key_len更大。
但是,具体key_len怎么计算的,上面怎样计算出是4和8的呢?之前没怎么关注过。在通过explain分析SQL查询语句的性能的时候,之前,我更多关注的是select_type、type、possible_key、key、ref、rows、extra,这次,我觉得有必要弄清楚key_len的计算.
1.所有的索引字段,如果没有设置not null,则需要加一个字节。
2.定长字段,int占四个字节、date占三个字节、char(n)占n个字符。
3.对于变成字段varchar(n),则有n个字符+两个字节。
4.不同的字符集,一个字符占用的字节数不同。latin1编码的,一个字符占用一个字节,gbk编码的,一个字符占用两个字节,utf8编码的,一个字符占用三个字节。
因此可以得出
where a=1 and c=1而言,key_len=4
where a=1 and b=1而言,key_len=4+4=8