`

MySQL使用EXPLAIN的key_len列

 
阅读更多

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

本文地址:http://flyer0126.iteye.com/blog/1889627

 

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

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

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

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

    

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

     

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

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

 

    参考资料:高性能MySQL

 

  • 大小: 5.7 KB
  • 大小: 5.6 KB
分享到:
评论

相关推荐

    关于MySQL EXPLAIN key_len的计算

    关于EXPLAIN的key_len 我们先看一个表的设计问题 可以看到上图中id、loginName、name、password这几个字段都设计成225长度的varchar字符串。其中id还是主键字段。 根据阿里巴巴的java代码规约,这里的字段命名有...

    浅谈mysql explain中key_len的计算方法

    在`EXPLAIN`的结果中,`key_len`字段提供了关于使用了索引的长度信息,这对于理解数据库如何利用索引以及优化查询至关重要。本文将深入探讨`key_len`的计算方法,并通过具体的示例来展示其工作原理。 首先,创建了...

    MySQL的查询计划中ken_len的值计算方法

    例如,如果我们取消`b`列的`NOT NULL`约束,即使查询仍然只使用`b`列,`key_len`可能会增加,因为它现在需要额外的1字节来存储可能的`NULL`标志。这意味着,尽管查询实际上只使用了一列,但`key_len` 显示的值可能比...

    Mysql Explain详细解析

    3. **使用 EXPLAIN ANALYZE**:在 MySQL 8.0.19 及更高版本中,可以通过 `EXPLAIN FORMAT=JSON` 或 `EXPLAIN ANALYZE` 来获取更详细的执行计划和性能数据。 4. **优化表结构**:如果 `EXPLAIN` 显示存在大量全表扫描...

    尚硅谷Java视频教程_MySQL高级视频

    尚硅谷_MySQL高级_explain之key_len介绍 · 27.尚硅谷_MySQL高级_explain之ref介绍 · 28.尚硅谷_MySQL高级_explain之rows介绍 · 29.尚硅谷_MySQL高级_explain之Extra介绍 · 30.尚硅谷_MySQL高级_explain之...

    02-VIP-Explain详解与索引最佳实践.pdf

    8. key_len 列:key_len 列表示当前查询所使用的索引的长度。 9. ref 列:ref 列表示当前查询所使用的连接方式,可以是 const、表名、函数等。 10. rows 列:rows 列表示当前查询所需扫描的行数。 11. filtered ...

    mysql高级视频教程百度云(2019).txt

    26.MySQL高级_explain之key_len介绍.avi 25.MySQL高级_explain之possible_keys和key介绍.avi 24.MySQL高级_explain之type介绍.avi 23.MySQL高级_explain之select_type和table介绍.avi 22.MySQL高级_explain...

    mysqlexplain.ppt

    6. **key_len**:索引使用的字节数,可用于估算索引长度。 7. **rows**:预计要检查的行数,预估值并非精确,但可提供性能参考。 8. **extra**:提供关于MySQL如何处理查询的额外信息,如使用了哪些优化策略,是否...

    mysql+explain实例分析

    7. **key_len**:使用到的索引长度。 8. **ref**:显示哪些列或常量被用来与索引比较。 9. **rows**:预计要检查的行数。 10. **Extra**:包含MySQL解决查询的额外信息,如“Using where”、“Using filesort”和...

    MySQL性能分析及explain的应用实践.docx

    例如,假设表有id、key1、key2、key3列,创建一个组合索引(id、key1、key2、key3),那么在查询时,只要满足最左原则,MySQL就会使用该索引。 3. 慢查询分析 慢查询分析是 MySQL 性能分析的重要步骤。可以在my....

    Mysql Explain

    ### MySQL Explain 深度解析 #### 一、Explain 的意义 在数据库查询优化领域,`EXPLAIN` 是一个非常强大的工具,它能够帮助我们分析 `SELECT` 语句的执行过程,揭示出查询效率低下的原因。通过 `EXPLAIN` 的分析...

    MySQL-Explain 详解

    7. key_len:表示当前查询使用的索引长度。 8. ref:表示当前查询使用的索引列。 9. rows:表示当前查询需要读取的行数。 10. filtered:表示当前查询的过滤率。 11. Extra:表示当前查询的额外信息。 三、索引类型...

    MySQL的Explain总结.doc

    8. **key_len列**: - 使用的索引长度,长度越短,索引覆盖的数据量越少,查询可能更快。 9. **ref列**: - 显示与key列中所用索引相比较的列或常量。 10. **rows列**: - 预估的需要检查的行数,数值越小,...

    MySQL explain 笔记整理

    - **key_len**:索引中使用的字节数。值越小,通常索引效率越高。 - **ref**:显示了使用哪个列或常量来查找行。如果是常量,则表示通过常量值来定位。 - **rows**:估计需要检查的行数。这个数字越大,通常查询...

    Mysql中explain的说明

    ### MySQL中EXPLAIN命令详解 #### 一、概述 在MySQL数据库管理中,查询优化是一项非常重要的工作。通过优化查询,不仅可以提升查询速度,还能节省系统资源...希望本文能帮助您更好地理解和使用MySQL的`EXPLAIN`功能。

Global site tag (gtag.js) - Google Analytics