FAQ系列|解讀EXPLAIN執行計劃中的key_len
導讀
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
相關文章
- MySQL執行計劃explain的key_len解析MySqlAI
- explain執行計劃中的key_len的計算規則AI
- Explain執行計劃詳解AI
- MySQL調優篇 | EXPLAIN執行計劃解讀(4)MySqlAI
- MySQL Explain執行計劃 - 詳解MySqlAI
- mysql explain 執行計劃詳解MySqlAI
- MySQL執行計劃EXPLAIN詳解MySqlAI
- MySQL explain 中 key_len的詳解MySqlAI
- (4) MySQL中EXPLAIN執行計劃分析MySqlAI
- explain執行計劃分析AI
- mysql執行計劃explainMySqlAI
- mysql explain 執行計劃MySqlAI
- MySQL執行計劃裡面的key_lenMySql
- oracle執行計劃的使用(EXPLAIN)OracleAI
- MySQL explain執行計劃詳細解釋MySqlAI
- 配置oracle 解釋執行計劃--explain planOracleAI
- explain 查詢執行計劃AI
- Hive底層原理:explain執行計劃詳解HiveAI
- 十六、Mysql之Explain執行計劃MySqlAI
- ORACLE執行計劃 explain說明OracleAI
- 【Explain Plan】檢視SQL的執行計劃AISQL
- mysql調優之——執行計劃explainMySqlAI
- Oracle執行計劃Explain Plan 如何使用OracleAI
- MongoDb學習之Explain執行計劃MongoDBAI
- Explain For理論執行計劃相關AI
- Oracle 執行計劃(Explain Plan) 說明OracleAI
- Oracle 執行計劃(Explain Plan) 說明OracleAI
- MySQL EXPLAIN命令詳解學習(檢視執行計劃)MySqlAI
- MySQL——通過EXPLAIN分析SQL的執行計劃MySqlAI
- mysql之 explain、optimizer_trace 執行計劃MySqlAI
- 使用EXPLAIN PLAN來檢視執行計劃AI
- TOAD中檢視執行計劃(Explain Plan)AI
- MySQL執行計劃explain輸出列結果解析MySqlAI
- 【最佳化】explain plan for 方式存取執行計劃AI
- 閱讀執行計劃
- 在MySQL中使用explain查詢SQL的執行計劃MySqlAI
- 執行計劃的閱讀方法
- 【執行計劃】格式化EXPLAIN PLAN的輸出結果AI