解读EXPLAIN执行计划中的key_len(转)
执行 解读 计划 Key explain len
2023-09-14 08:58:45 时间
原文:http://imysql.com/2015/10/20/mysql-faq-key-len-in-explain.shtml
导读
EXPLAIN中的key_len一列表示什么意思,该如何解读?
EXPLAIN执行计划中有一列 key_len 用于表示本次查询中,所选择的索引长度有多少字节,通常我们可借此判断联合索引有多少列被选择了。key_len越短越好,说白了就是字段类型越短越好
在这里 key_len 大小的计算规则是:
- 一般地,key_len 等于索引列类型字节长度,例如int类型为4-bytes,bigint为8-bytes;
- 如果是字符串类型,还需要同时考虑字符集因素,例如:CHAR(30) UTF8则key_len至少是90-bytes;
- 若该列类型定义时允许NULL,其key_len还需要再加 1-bytes;
- 若该列类型为变长类型,例如 VARCHAR(TEXT\BLOB不允许整列创建索引,如果创建部分索引,也被视为动态列类型),其key_len还需要再加 2-bytes;
综上,看下面几个例子:
列类型 | KEY_LEN | 备注 |
---|---|---|
id int | key_len = 4+1 = 5 | 允许NULL,加1-byte |
id int not null | key_len = 4 | 不允许NULL |
user char(30) utf8 | key_len = 30*3+1 | 允许NULL |
user varchar(30) not null utf8 | key_len = 30*3+2 | 动态列类型,加2-bytes |
user varchar(30) utf8 | key_len = 30*3+2+1 | 动态列类型,加2-bytes;允许NULL,再加1-byte |
detail text(10) utf8 | key_len = 30*3+2+1 | TEXT列截取部分,被视为动态列类型,加2-bytes;且允许NULL |
备注,key_len 只指示了WHERE中用于条件过滤时被选中的索引列,是不包含 ORDER BY/GROUP BY 这部分被选中的索引列。
例如,有个联合索引 idx1(c1, c2, c3),3个列均是INT NOT NULL,那么下面的这个SQL执行计划中,key_len的值是8而不是12:
SELECT…WHERE c1=? AND c2=? ORDER BY c1;
相关文章
- touchesBegan: withEvent: 不执行/完美收起键盘
- 关于 SAP 电商云 Spartacus UI Navigation Service 执行的一些明细
- Maven插件方式执行CheckStyle并自定义风格文件
- 解读:OpenSea的强制版税执行工具
- Shell(Bash)多命令顺序执行方法详解
- 运行Linux SH脚本实现简便操作(linuxsh脚本执行)
- lookLinux下运行Outlook:改变办公模式的新方法(linux执行out)
- 模板引擎注射:针对现代web应用的新型命令执行
- 优化MySQL执行效率:提高数据库操作速度的关键技巧(mysql执行效率)
- SQL Server预编译:提升执行效率的有效手段(sqlserver预编译)
- 解读mysql执行信息,优化数据库性能(mysql_ 执行的信息)
- 借助Oracle,轻松实现高效的执行计划管理(oracle保留执行计划)
- Redis事物一种可靠的原子性执行方式(什么是redis事物)
- 解读IE和firefox下JScript和HREF的执行顺序