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
相关文章:
高防服务器租用首荐平台,企业级优惠套餐快速部署
如何基于云服务器快速搭建网站及云盘系统?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何通过WDCP绑定主域名及创建子域名站点?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
建站之星2.7模板快速切换与批量管理功能操作指南
济南企业网站制作公司,济南社保单位网上缴费步骤?
行程制作网站有哪些,第三方机票电子行程单怎么开?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
如何用AWS免费套餐快速搭建高效网站?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
淘宝制作网站有哪些,淘宝网官网主页?
制作网站的软件免费下载,免费制作app哪个平台好?
如何设置并定期更换建站之星安全管理员密码?
如何在腾讯云免费申请建站?
宝塔新建站点报错如何解决?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
公司网站设计制作厂家,怎么创建自己的一个网站?
网站好制作吗知乎,网站开发好学吗?有什么技巧?
Android使用GridView实现日历的简单功能
网站设计制作公司地址,网站建设比较好的公司都有哪些?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
电商平台网站制作流程,电商网站如何制作?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
家庭建站与云服务器建站,如何选择更优?
建站主机服务器选型指南与性能优化方案解析
如何在腾讯云服务器上快速搭建个人网站?
建站之星微信建站一键生成小程序+多端营销系统
如何通过云梦建站系统实现SEO快速优化?
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?
济南专业网站制作公司,济南信息工程学校怎么样?
智能起名网站制作软件有哪些,制作logo的软件?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
,如何利用word制作宣传手册?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
b2c电商网站制作流程,b2c水平综合的电商平台?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
自助网站制作软件,个人如何自助建网站?
建站之星展会模版如何一键下载生成?
,石家庄四十八中学官网?
北京网站制作的公司有哪些,北京白云观官方网站?
定制建站价位费用解析与套餐推荐全攻略
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
建站之星如何保障用户数据免受黑客入侵?
*请认真填写需求信息,我们会在24小时内与您取得联系。