導讀
EXPLAIN中的key_len一列表示什麼意思,該如何解讀?
EXPLAIN執行計劃中有一列 key_len 用於表示本次查詢中,所選擇的索引長度有多少字節,通常我們可藉此判斷聯合索引有多少列被選擇了。
在這裏 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;
綜上,看下面幾個例子:
列類型 | 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: