There is a column of key_len in the result of executing explain in Mysql, so what is the meaning of key_len?
key_len: Indicates the number of bytes used by the index. Based on this value, the usage of the index can be judged. Especially when combining indexes, it is very important to judge how many parts of the index are used.
Additional information on index fields: can be divided into variable-length and fixed-length data types for discussion. When index fields When it is a fixed-length data type, such as char, int, datetime, a mark is required to indicate whether it is empty. This mark occupies 1 byte (for fields that are not null, this 1 byte is not required); for variable-length fields Data types, such as varchar, need to have length information in addition to the empty mark, which takes up two bytes.
For character sets such as char, varchar, blob, text, etc., the length of key len is also related to the character set. One character of latin1 occupies 1 byte, and one character of gbk occupies one byte. 2 bytes, one UTF8 character occupies 3 bytes.
Example:
Column type | KEY_LEN | Remarks |
---|---|---|
id int | key_len = 4 1 | int is 4bytes, NULL is allowed, add 1byte |
id bigint not null | key_len=8 | bigint is 8bytes |
key_len=30*3 1 | Each character of utf8 is 3 bytes, NULL is allowed, add 1 byte | |
key_len=30*3 2 | utf8 each character is 3 bytes, variable length data type, add 2 bytes | ##user varchar(30) utf8 |
utf8 each character is 3 bytes, NULL is allowed, add 1 byte, variable length data type, add 2 bytes | detail text(10) utf8 | |
TEXT intercepted part is regarded as a dynamic column type. |
ExampleThe following is a specific example to illustrate, table structure:For example, there is a joint index idx (c1, c2, c3), and the three columns are all int not null, then in the following SQL execution plan, the value of key_len is 8 instead of 12:
select ... from tb where c1=? and c2=? order by c1;Copy after login
CREATE TABLE `t4` ( `id` int(11) NOT NULL AUTO_INCREMENT, `a` int(11) NOT NULL DEFAULT '0', `b` int(11) NOT NULL DEFAULT '0', `c` int(11) NOT NULL DEFAULT '0', PRIMARY KEY (`id`), KEY `index1` (`a`,`b`) ) ENGINE=InnoDB;
mysql> explain select * from t4 where a =0 and b > 0; +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+ | 1 | SIMPLE | t4 | range | index1 | index1 | 8 | NULL | 1 | Using where | +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+ mysql> explain select * from t4 where a > 0 and b = 0; +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+ | 1 | SIMPLE | t4 | range | index1 | index1 | 4 | NULL | 1 | Using where | +----+-------------+-------+-------+---------------+--------+---------+------+------+-------------+
The above is the detailed content of What is the meaning of key_len in mysql explain and how to calculate it. For more information, please follow other related articles on the PHP Chinese website!