MySQL Explain中key_len的计算

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

通常在优化SQL查询的时候,我们都会使用explain分析SQL执行计划,通常来说当用到组合索引的时候我们如何判断索引完全用上呢?当然高手看看表结构及SQL语句就知道到底用到了几个字段,对于不熟悉的同学呢?我们还是可以看看key_len的长度,当然这个计算还是有点复杂的,下面我们来谈谈explain key_len如何计算的。


a.表结构如下:

CREATE TABLE keylen_cal (
  id int(10) NOT NULL,
  tel int(10) DEFAULT NULL,
  first_name varchar(10) NOT NULL,
  last_name varchar(10) DEFAULT NULL,
  father char(10) NOT NULL,
  mother char(10) DEFAULT NULL,  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
b.插入数据
insert into keylen_cal values (1,111,'A','AA','AAA','AAAA');
insert into keylen_cal values (2,222,'B','BB','BBB','BBBB');
insert into keylen_cal values (3,333,'C','CC','CCC','CCCC');
insert into keylen_cal values (4,444,'D','DD','DDD','DDDD');
c创建索引
alter table keylen_cal add index idx_id(id);
alter table keylen_cal add index idx_tel(tel);
alter table keylen_cal add index idx_fn(first_name);
alter table keylen_cal add index idx_ln(last_name);
alter table keylen_cal add index idx_father(father);
alter table keylen_cal add index idx_mother(mother);


d.测试每个key_len的长度

explain select * from keylen_cal where id=3;
##id int(10) NOT NULL,
key_len=4

explain select * from keylen_cal where tel=33;
##tel int(10) DEFAULT NULL,
key_len=5=4+1

alter table keylen_cal modify id(100) NOT NULL;
explain select * from keylen_cal where id=3;
key_len=4

explain select * from keylen_cal where first_name='C'
##first_name varchar(10) NOT NULL,
key_len=32=10*3+2 (utf8占用三个字节)

explain select * from keylen_cal where last_name='CC'
##last_name varchar(10) DEFAULT NULL,
key_len=33=10*3+2+1

explain select * from keylen_cal where father='CCC'
##father char(10) NOT NULL
key_len=30=3*10

explain select * from keylen_cal where mother='CCCC'
##mother char(10) DEFAULT NULL
key_len=31=3*10+1

通过上面的一系列实验,可以总结出来如下规律

  1. 通常情况下, key_len=字段字符数*字符集每个字符所占字节数

  2. default null ,会使 key_len+1

  3. 变长的字段如varchar,会使key_len+2

  4. int ,key_len=4

  5. bigint, key_len=8



相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
51 3
|
2月前
|
存储 监控 关系型数据库
MySQL计算某条数据与上一条数据的生成时间差
MySQL计算某条数据与上一条数据的生成时间差
48 2
|
2月前
|
SQL 关系型数据库 MySQL
MySQL EXPLAIN该如何分析?
本文将详细介绍MySQL中`EXPLAIN`关键字的工作原理及结果字段解析,帮助优化查询性能。`EXPLAIN`可显示查询SQL的执行计划,其结果包括`id`、`select_type`、`table`等字段。通过具体示例和优化建议,帮助你理解和应用`EXPLAIN`,提升数据库查询效率。
99 0
|
5月前
|
SQL 关系型数据库 MySQL
mysql性能调优:EXPLAIN命令21
【7月更文挑战第21天】掌握SQL性能调优:深入解析EXPLAIN命令的神奇用法!
64 1
|
5月前
|
SQL 缓存 关系型数据库
MySQL|浅谈explain的使用
【7月更文挑战第11天】
|
5月前
|
SQL 存储 数据库
MySQL设计规约问题之性能分析工具如Sql explain、show profile和mysqlsla在数据库性能优化中有什么作用
MySQL设计规约问题之性能分析工具如Sql explain、show profile和mysqlsla在数据库性能优化中有什么作用
|
5月前
|
SQL 索引 关系型数据库
MySQL设计规约问题之为什么推荐使用EXPLAIN来检查SQL查询
MySQL设计规约问题之为什么推荐使用EXPLAIN来检查SQL查询
|
5天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
25天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
34 1