如何精確計算mysql的索引長度


一、前言

MySQL Innodb 對於索引長度的限制為 767 字節,並且UTF8mb4字符集是4字節字符集,則 767字節 / 4字節每字符 = 191字符(默認索引最大長度),所以在varchar(255)或char(255) 類型字段上創建索引會失敗,提示最大索引長度為767字節。

二、環境准備

創建表

CREATE TABLE `t` (
  `a` int(5) NOT NULL,
  `b` int(5) NOT NULL,
  `c` int(2) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

創建聯合索引

create index idx_all on t(a,b,c);

三、試驗

  1、執行下面兩條語句

explain select * from t where a=1 and c=1;
explain select * from t where a=1 and b=1;

 

語句1的執行計划為:

 

 語句2的執行計划為:

  2、思路

查看表的索引

show index from t;

 

將組合索引想成書的一級目錄、二級目錄、三級目錄,如index(a,b,c),相當於a是一級目錄,b是一級目錄下的二級目錄,c是二級目錄下的三級目錄。要使用某一目錄,必須先使用其上級目錄,除了一級目錄除外。

所以

where a=1 and c=1只使用了一級目錄,c在三級目錄,沒有使用二級目錄,那么三級目錄就沒法使用

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

於是第二條查詢的key_len更大。

但是,具體key_len怎么計算的,上面怎樣計算出是4和8的呢?

  3、索引長度的計算規則

1.所有的索引字段,如果沒有設置not null,則需要加一個字節。

2.定長字段,int占四個字節、date占三個字節、char(n)占n個字符。

3.對於變成字段varchar(n),則有n個字符+兩個字節。

4.不同的字符集,一個字符占用的字節數不同。latin1編碼的,一個字符占用一個字節,gbk編碼的,一個字符占用兩個字節,utf8編碼的,一個字符占用三個字節。

5.索引長度 char()、varchar()索引長度的計算公式:

(Character Set:utf8mb4=4,utf8=3,gbk=2,latin1=1) * 列長度 + 1(允許null) + 2(變長列)

  4、再看sql語句

SQL1

select * from t where a=1 and c=1;

執行計划:

key_len = 4 (a是int類型 4字節) = 4

所以得出結論,是命中了索引列a

SQL2

explain select * from t where a=1 and b=1;

執行計划:

key_len =4 (a是int類型 4字節) + 4(b是int類型 4字節)  = 8

所以得出結論,是命中了索引列a和索引列b

四、再實驗

  1、創建表

create table t2(id int(5) not null,name varchar(5) not null) engine=innodb default charset=latin1;

  2、創建索引

create index idx_2 on t2(id,name);

  3、計算索引字段

sql為:

explain select * from t2 where name="001" and id=1;

 執行計划為:

 key_len =4 (id是int類型 4字節) + 5(name是varcharr類型 5字節)*1(字符集是latin1)+變列長2  = 11


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM