mysql sql len_MySQL使用EXPLAIN的key_len列

PS:原创文章,如需转载,请注明出处,谢谢!

几天前跟一个同事讨论SQL执行计划时说到key_len的问题,概念有些模糊,于是今天来理解一下。

key_len列,显示了MySQL在索引里使用的字节数。

如users表的主键是int类型的列,一个int有4个字节,那么索引里的每一项就是4个字节,一下是一个查询的示例:

mysql> EXPLAIN SELECT username FROM users WHERE id = 3;

36ea1d5b809257f3fcd86aa658916caa.png

基于查询结果里的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;

5722cfaa48341a7c6b0040a601a4cf95.png

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

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

参考资料:高性能MySQL

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值