浅谈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资料中心布局

