explain執行計劃中的key_len的計算規則

chenfeng發表於2017-04-26
它的規則如下:

1.所有的索引欄位,如果沒有設定not null,則需要加一個位元組。
2.定長欄位,int佔四個位元組、date佔三個位元組、char(n)佔n個字元。
3.對於變成欄位varchar(n),則有n個字元+兩個位元組。
4.不同的字符集,一個字元佔用的位元組數不同。latin1編碼的,一個字元佔用一個位元組,gbk編碼的,一個字元佔用兩個位元組,utf8編碼的,一個字元佔用三個位元組。


舉例說明:

mysql> desc person;
+-------+--------------+------+-----+---------+-------+
| Field | Type         | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+-------+
| id    | varchar(100) | NO   | PRI |         |       |
| name  | varchar(100) | YES  | MUL | NULL    |       |
| age   | int(10)      | YES  |     | NULL    |       |
+-------+--------------+------+-----+---------+-------+
3 rows in set (0.00 sec)


檢視索引情況:
mysql> show index from person;
+--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table  | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| person |          0 | PRIMARY  |            1 | id          | A         |           2 |     NULL | NULL   |      | BTREE      |         |               |
| person |          1 | idx_name |            1 | name        | A         |           2 |     NULL | NULL   | YES  | BTREE      |         |               |
+--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
2 rows in set (0.00 sec)


mysql> explain select name from person;
+----+-------------+--------+-------+---------------+----------+---------+------+------+-------------+
| id | select_type | table  | type  | possible_keys | key      | key_len | ref  | rows | Extra       |
+----+-------------+--------+-------+---------------+----------+---------+------+------+-------------+
|  1 | SIMPLE      | person | index | NULL          | idx_name | 103     | NULL |    2 | Using index |
+----+-------------+--------+-------+---------------+----------+---------+------+------+-------------+
1 row in set (0.00 sec)


根據以上計算規則:
所有的索引欄位,如果沒有設定not null,則需要加一個位元組
對於變成欄位varchar(n),則有n個字元+兩個位元組
因此:key_len=100+2+1=103

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2138031/,如需轉載,請註明出處,否則將追究法律責任。

相關文章