日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql key_len_浅谈mysql explain中key_len的计算方法

發布時間:2025/3/8 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql key_len_浅谈mysql explain中key_len的计算方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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 key_len_浅谈mysql explain中key_len的计算方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。