佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > 淺談mysql explain中key_len的計(jì)算方法

淺談mysql explain中key_len的計(jì)算方法

熱門(mén)標(biāo)簽:地方門(mén)戶(hù)網(wǎng)站 呼叫中心市場(chǎng)需求 鐵路電話(huà)系統(tǒng) Linux服務(wù)器 服務(wù)外包 網(wǎng)站排名優(yōu)化 AI電銷(xiāo) 百度競(jìng)價(jià)排名

mysql的explain命令可以分析sql的性能,其中有一項(xiàng)是key_len(索引的長(zhǎng)度)的統(tǒng)計(jì)。本文將分析mysql explain中key_len的計(jì)算方法。

1、創(chuàng)建測(cè)試表及數(shù)據(jù)

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的字段類(lèi)型是varchar(20),字符編碼是utf8,一個(gè)字符占用3個(gè)字節(jié),那么key_len應(yīng)該是 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再測(cè)試

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 |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+

現(xiàn)在key_len為62,比剛才少了1,但還是多了2??梢源_定,字段為NULL會(huì)多占用一個(gè)字節(jié)。

name字段類(lèi)型為varchar,屬于變長(zhǎng)字段,把varchar改為char再測(cè)試

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 |
+----+-------------+--------+------+---------------+------+---------+-------+------+-----------------------+

改為定長(zhǎng)字段后,key_len為60,與預(yù)測(cè)的一致。

總結(jié):使用變長(zhǎng)字段需要額外增加2個(gè)字節(jié),使用NULL需要額外增加1個(gè)字節(jié),因此對(duì)于是索引的字段,最好使用定長(zhǎng)和NOT NULL定義,提高性能。

以上這篇淺談mysql explain中key_len的計(jì)算方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • mysql計(jì)算時(shí)間差函數(shù)
  • Mysql中通過(guò)生日計(jì)算年齡的多種方法
  • 在php和MySql中計(jì)算時(shí)間差的方法
  • mysql 字符串長(zhǎng)度計(jì)算實(shí)現(xiàn)代碼(gb2312+utf8)
  • Mysql數(shù)據(jù)庫(kù)的QPS和TPS的意義和計(jì)算方法
  • MySQL幾點(diǎn)重要的性能指標(biāo)計(jì)算和優(yōu)化方法總結(jié)
  • MySQL的查詢(xún)計(jì)劃中ken_len的值計(jì)算方法
  • mysql日期和時(shí)間的間隔計(jì)算實(shí)例分析
  • MySQL日期加減函數(shù)詳解
  • mysql 觸發(fā)器創(chuàng)建與使用方法示例
  • MySQL觸發(fā)器基本用法詳解【創(chuàng)建、查看、刪除等】
  • mysql累加計(jì)算實(shí)現(xiàn)方法詳解

標(biāo)簽:衡水 湘潭 湖南 蘭州 銅川 崇左 黃山 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺談mysql explain中key_len的計(jì)算方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話(huà)咨詢(xún)

    • 400-1100-266
    元阳县| 杭州市| 山阴县| 淅川县| 梁平县| 新源县| 延津县| 荣成市| 南皮县| 阆中市| 逊克县| 吴忠市| 泰兴市| 巴中市| 连江县| 长岛县| 兰坪| 婺源县| 麻栗坡县| 泰顺县| 汝州市| 肥城市| 石台县| 冕宁县| 即墨市| 大兴区| 塔城市| 黄龙县| 潜山县| 克拉玛依市| 乌什县| 六枝特区| 胶南市| 逊克县| 连平县| 黑山县| 景宁| 灵丘县| 磐石市| 钟祥市| 贵溪市|