FAQ系列|解讀EXPLAIN執行計劃中的key_len

晚來風急發表於2017-08-02

導讀

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(TEXTBLOB不允許整列建立索引,如果建立部分索引,也被視為動態列型別),其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;

文章轉自老葉茶館公眾號,原文連結:https://mp.weixin.qq.com/s/TTLBidTBUuMMYJM9h1_Olg


相關文章