亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2017年04月05日 11:01:04   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇淺談mysql explain中key_len的計(jì)算方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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的字段類型是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字段類型為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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL之死鎖問(wèn)題及其解決方案

    MySQL之死鎖問(wèn)題及其解決方案

    數(shù)據(jù)庫(kù)死鎖問(wèn)題是我們老生常談的問(wèn)題了,在我們實(shí)際開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)遇到,本文主要介紹了MySQL之死鎖問(wèn)題及其解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • MySql中 is Null段判斷無(wú)效和IFNULL()失效的解決方案

    MySql中 is Null段判斷無(wú)效和IFNULL()失效的解決方案

    這篇文章主要介紹了MySql中 is Null段判斷無(wú)效和IFNULL()失效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Mysql之索引長(zhǎng)度限制方式

    Mysql之索引長(zhǎng)度限制方式

    這篇文章主要介紹了Mysql之索引長(zhǎng)度限制方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MySQL連接無(wú)法解析HOST主機(jī)名的解決方法

    MySQL連接無(wú)法解析HOST主機(jī)名的解決方法

    這篇文章主要介紹了MySQL連接無(wú)法解析HOST主機(jī)名的解決方法,需要的朋友可以參考下
    2014-02-02
  • 計(jì)算機(jī)二級(jí)考試MySQL知識(shí)點(diǎn) mysql alter命令

    計(jì)算機(jī)二級(jí)考試MySQL知識(shí)點(diǎn) mysql alter命令

    這篇文章主要為大家詳細(xì)介紹了計(jì)算機(jī)二級(jí)考試MySQL知識(shí)點(diǎn),詳細(xì)介紹了mysql中alter命令的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • MYSQL?SQL查詢近7天一個(gè)月的數(shù)據(jù)的操作方法

    MYSQL?SQL查詢近7天一個(gè)月的數(shù)據(jù)的操作方法

    這篇文章主要介紹了MYSQL?SQL查詢近7天一個(gè)月的數(shù)據(jù)的操作方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • MySQL刪除了記錄不生效的原因排查

    MySQL刪除了記錄不生效的原因排查

    這篇文章主要介紹了MySQL刪除了記錄不生效的原因排查,幫助大家解決MySQL刪除語(yǔ)句不生效的問(wèn)題,感興趣的朋友可以了解下
    2020-11-11
  • 在MySQL中使用通配符時(shí)應(yīng)該注意的問(wèn)題

    在MySQL中使用通配符時(shí)應(yīng)該注意的問(wèn)題

    這篇文章主要介紹了在MySQL中使用通配符時(shí)應(yīng)該注意的問(wèn)題,主要是下劃線的使用容易引起的錯(cuò)誤,需要的朋友可以參考下
    2015-05-05
  • 淺談Mysql insert on duplicate key 死鎖問(wèn)題定位與解決

    淺談Mysql insert on duplicate key 死鎖問(wèn)

    本文介紹了在并發(fā)場(chǎng)景下的 insert on duplicate key update sql 出現(xiàn)的死鎖,經(jīng)過(guò)分析發(fā)現(xiàn)這種sql確實(shí)比較容易造成死鎖,這篇文章就從分析死鎖展開(kāi),到最終如何解決這樣的問(wèn)題 分享相應(yīng)的思路,感興趣的可以了解一下
    2022-05-05
  • mysql服務(wù)啟動(dòng)卻連接不上的解決方法

    mysql服務(wù)啟動(dòng)卻連接不上的解決方法

    這篇文章主要為大家詳細(xì)介紹了mysql服務(wù)啟動(dòng)卻連接不上的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評(píng)論