浅谈mysql explain中key_len的计算方法

发布时间 - 2026-01-11 00:31:06    点击率:

mysql的explain命令可以分析sql的性能,其中有一项是key_len(索引的长度)的统计。本文将分析mysql explain中key_len的计算方法。

1、创建测试表及数据

CREATE TABLE `member` (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
 `name` varchar(20) DEFAULT NULL,
 `age` tinyint(3) unsigned DEFAULT NULL,
 PRIMARY KEY (`id`),
 KEY `name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `member` (`id`, `name`, `age`) VALUES (NULL, 'fdipzone', '18'), (NULL, 'jim', '19'), (NULL, 'tom', '19');

2、查看explain

name的字段类型是varchar(20),字符编码是utf8,一个字符占用3个字节,那么key_len应该是 20*3=60

mysql> explain select * from `member` where name='fdipzone';
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref  | rows | Extra         |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| 1 | SIMPLE   | member | ref | name     | name | 63   | const |  1 | Using index condition |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+

explain的key_len为63,多出了3

name字段是允许NULL,把name改为NOT NULL再测试

ALTER TABLE `member` CHANGE `name` `name` VARCHAR(20) NOT NULL;

mysql> explain select * from `member` where name='fdipzone';
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref  | rows | Extra         |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| 1 | SIMPLE   | member | ref | name     | name | 62   | const |  1 | Using index condition |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+

现在key_len为62,比刚才少了1,但还是多了2。可以确定,字段为NULL会多占用一个字节。

name字段类型为varchar,属于变长字段,把varchar改为char再测试

ALTER TABLE `member` CHANGE `name` `name` CHAR(20) NOT NULL;

mysql> explain select * from `member` where name='fdipzone';
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref  | rows | Extra         |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+
| 1 | SIMPLE   | member | ref | name     | name | 60   | const |  1 | Using index condition |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+

改为定长字段后,key_len为60,与预测的一致。

总结:使用变长字段需要额外增加2个字节,使用NULL需要额外增加1个字节,因此对于是索引的字段,最好使用定长和NOT NULL定义,提高性能。

以上这篇浅谈mysql explain中key_len的计算方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# mysql  # explain  # keylen  # mysql explain中key_len的含义以及计算方法  # 给大家  # 计算方法  # 变长  # 定长  # 中有  # 希望能  # 少了  # 这篇  # 浅谈  # 多出  # 小编  # 大家多多  # 长和  # 应该是  # varchar  # AUTO_INCREMENT  # unsigned  # int  # NULL  # ENGINE 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑  如何确保FTP站点访问权限与数据传输安全?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  如何在服务器上三步完成建站并提升流量?  Laravel如何为API编写文档_Laravel API文档生成与维护方法  怎样使用JSON进行数据交换_它有什么限制  zabbix利用python脚本发送报警邮件的方法  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  JavaScript实现Fly Bird小游戏  海南网站制作公司有哪些,海口网是哪家的?  无锡营销型网站制作公司,无锡网选车牌流程?  bing浏览器学术搜索入口_bing学术文献检索地址  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  网站制作软件有哪些,制图软件有哪些?  如何在阿里云虚拟服务器快速搭建网站?  Android实现代码画虚线边框背景效果  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  MySQL查询结果复制到新表的方法(更新、插入)  JavaScript如何实现类型判断_typeof和instanceof有什么区别  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何用已有域名快速搭建网站?  Laravel如何使用Blade模板引擎?(完整语法和示例)  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  详解阿里云nginx服务器多站点的配置  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  如何快速上传建站程序避免常见错误?  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Bootstrap CSS布局之列表  Android GridView 滑动条设置一直显示状态(推荐)  如何为不同团队 ID 动态生成多个非值班状态按钮  如何用JavaScript实现文本编辑器_光标和选区怎么处理  如何在建站之星绑定自定义域名?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  再谈Python中的字符串与字符编码(推荐)  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  Laravel如何升级到最新版本?(升级指南和步骤)  Laravel怎么使用Intervention Image库处理图片上传和缩放  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何在IIS中新建站点并配置端口与物理路径?  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  如何安全更换建站之星模板并保留数据?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  大型企业网站制作流程,做网站需要注册公司吗?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局