MySQL中計(jì)算索引長(zhǎng)度的詳情

首先,我們來(lái)看一道題目,針對(duì)表t,包含了三個(gè)字段a、b、c,假設(shè)其默認(rèn)值都非空,現(xiàn)創(chuàng)建組合索引index(a,b,c) 分析select * from t where a=1 and c=1 和select * from t where a=1 and b=1區(qū)別?

首先創(chuàng)建表

MySQL中計(jì)算索引長(zhǎng)度的詳情

分別執(zhí)行這兩條語(yǔ)句

MySQL中計(jì)算索引長(zhǎng)度的詳情

發(fā)現(xiàn),兩則區(qū)別主要是在于key_len上,為什么二則區(qū)別不一樣呢?

我的理解是:

我們可以講組合索引想成書(shū)的一級(jí)目錄、二級(jí)目錄、三級(jí)目錄,如index(a,b,c),相當(dāng)于a是一級(jí)目錄,b是一級(jí)目錄下的二級(jí)目錄,c是二級(jí)目錄下的三級(jí)目錄。要使用某一目錄,必須先使用其上級(jí)目錄,除了一級(jí)目錄除外。

所以

where a=1 and c=1只使用了一級(jí)目錄,c在三級(jí)目錄,沒(méi)有使用二級(jí)目錄,那么三級(jí)目錄就沒(méi)法使用

where a=1 and b=1只使用了一級(jí)目錄、二級(jí)目錄。

于是第二條查詢(xún)的key_len更大。


但是,具體key_len怎么計(jì)算的,上面怎樣計(jì)算出是4和8的呢?之前沒(méi)怎么關(guān)注過(guò)。在通過(guò)explain分析SQL查詢(xún)語(yǔ)句的性能的時(shí)候,之前,我更多關(guān)注的是select_type、type、possible_key、key、ref、rows、extra,這次,我覺(jué)得有必要弄清楚key_len的計(jì)算.

1.所有的索引字段,如果沒(méi)有設(shè)置not null,則需要加一個(gè)字節(jié)。

2.定長(zhǎng)字段,int占四個(gè)字節(jié)、date占三個(gè)字節(jié)、char(n)占n個(gè)字符。

3.對(duì)于變成字段varchar(n),則有n個(gè)字符+兩個(gè)字節(jié)。
4.不同的字符集,一個(gè)字符占用的字節(jié)數(shù)不同。latin1編碼的,一個(gè)字符占用一個(gè)字節(jié),gbk編碼的,一個(gè)字符占用兩個(gè)字節(jié),utf8編碼的,一個(gè)字符占用三個(gè)字節(jié)。

因此可以得出

where a=1 and c=1而言,key_len=4

where a=1 and c=1而言,key_len=4+4=8


現(xiàn)在再來(lái)做一道題,創(chuàng)建一個(gè)t2表,數(shù)據(jù)結(jié)構(gòu)如下

MySQL中計(jì)算索引長(zhǎng)度的詳情

求執(zhí)行explain select * from t2 where name=”001″ and id=1 G;的key_len是多少呢?

分析key_len=4+5*1+2=11,因?yàn)樽侄味际莕ot null,int類(lèi)型4個(gè)字節(jié),varchar(5) 占用5個(gè)字符+2個(gè)字節(jié),latin1編碼的表一個(gè)字符占1個(gè)字節(jié),故varchar(5) 占用7個(gè)字節(jié)。結(jié)構(gòu)如下圖

MySQL中計(jì)算索引長(zhǎng)度的詳情

補(bǔ)充

因?yàn)镸ySQL具有查詢(xún)優(yōu)化器,所以對(duì)where a=1 and c=1類(lèi)型的查詢(xún),字段順序沒(méi)有任何影響,查詢(xún)優(yōu)化器會(huì)自動(dòng)優(yōu)化。where c=1 and a=1會(huì)被優(yōu)化成where a=1 and c=1,但是建議還是使用where a=1 and c=1吧,便于理解以及查詢(xún)緩沖。因?yàn)椴樵?xún)緩沖,hashkey值,是以sql語(yǔ)句來(lái)計(jì)算的,且區(qū)分大小寫(xiě),所以在寫(xiě)SQL語(yǔ)句的時(shí)候,盡量保存一致,防止相同的查詢(xún)被緩存多次。

?以上就是MySQL中計(jì)算索引長(zhǎng)度的詳情的內(nèi)容,更多相關(guān)內(nèi)容請(qǐng)關(guān)注PHP中文網(wǎng)(www.php.cn)!

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊8 分享