mysql explain中key_len的計算

來源:互聯網
上載者:User

標籤:

ken_len表示索引使用的位元組數,根據這個值,就可以判斷索引使用方式,特別是在複合式索引的時候,判斷是否所有的索引欄位都被查詢用到。

key_len顯示了條件檢索子句需要的索引長度,但 ORDER BY、GROUP BY 子句用到的索引則不計入 key_len 統計值;

關於 key_len 的計算規則:

• 當索引欄位為定長資料類型,比如:char,int,datetime,需要有是否為空白的標記,這個標記需要佔用1個位元組;
• 當索引欄位為變長資料類型,比如:varchar,除了是否為空白的標記外,還需要有長度資訊,需要佔用2個位元組;
• 當欄位定義為非空的時候,是否為空白的標記將不佔用位元組;
• 同時還需要考慮表所使用字元集的差異,latin1編碼一個字元1個位元組,gbk編碼一個字元2個位元組,utf8編碼一個字元3個位元組;

 

key_len長度的計算公式

• varchr(10)變長欄位且允許NULL : 10*(Character Set:utf8=3,gbk=2,latin1=1)+1(NULL標記位)+2(變長欄位)
• varchr(10)變長欄位且不允許NULL : 10*(Character Set:utf8=3,gbk=2,latin1=1)+2(變長欄位)
• char(10)固定欄位且允許NULL : 10*(Character Set:utf8=3,gbk=2,latin1=1)+1(NULL標記位)
• char(10)固定欄位且不允許NULL : 10*(Character Set:utf8=3,gbk=2,latin1=1)

 

mysql explain中key_len的計算

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.