首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网络技术 > 网络基础 >

MySQL运用EXPLAIN的key_len列

2013-07-01 
MySQL使用EXPLAIN的key_len列mysql EXPLAIN SELECT username FROM users WHERE id 3? ??? ? ? ? 基于

MySQL使用EXPLAIN的key_len列
mysql> EXPLAIN SELECT username FROM users WHERE id = 3;

? ??MySQL运用EXPLAIN的key_len列

? ? ? ? 基于查询结果里的key_len列,能够推断出查询执行索引查找时仅仅使用了第一列,即id。当计算列的使用情况时,要确保考虑到了字符列里的字符集类型:

mysql> CREATE TABLE T (       ->  a char(3) NOT NULL,       ->  b int(11) NOT NULL,       ->  c char(1) NOT NULL,       ->  PRIMARY KEY (a,b,c)       ->  ) ENGINE=MyISAM DEFAULT CHARSET=utf8;mysql> INSERT INTO t VALUES('11', 1, 'a');mysql> INSERT INTO t VALUES('22', 2, 'b');mysql> INSERT INTO t VALUES('33', 3, 'c');mysql> EXPLAIN SELECT a FROM t WHERE a = '11' AND b = 1;

?? ??MySQL运用EXPLAIN的key_len列

? ? ? ? 本次查询里的key_len为13个字节长度就是a列和b列的长度之和。a是3个字符,utf8格式,所以每一个是3个字节,b列是4个字节的整数。

? ? ? ? key_len列显示的是索引字段的最大可能长度,不是表内数据使用的真正字节数。前面例子里显示为13个字节数,哪怕a列没有数据,也就是说,key_len是根据表的定义计算出来的,而不是通过表内数据检索出来的。

?

? ? 参考资料:高性能MySQL

?

热点排行