成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

優化體系 | 我是怎么計算MySQL數據庫索引長度的?

數據庫 MySQL 新聞
我們知道MySQL Innodb 對于索引長度的限制為 767 字節,并且UTF8mb4字符集是4字節字符集,則 767字節 / 4字節每字符 = 191字符(默認索引最大長度),所以在varchar(255)或char(255) 類型字段上創建索引會失敗,提示最大索引長度為767字節。

概述

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

那么怎么去計算mysql數據庫索引長度呢?

[[271474]]

實驗測試

先看網上一道題目,針對表t,包含了三個字段a、b、c,假設其默認值都非空,現創建組合索引index(a,b,c) 分析select * from t where a=1 and c=1 和select * from t where a=1 and b=1區別?

1、創建表

  1. create table t(a int(5) not null,b int(5) not null,c int(2) not null); 
  2. create index idx_all on t(a,b,c); 
優化體系--我是怎么計算mysql數據庫索引長度的?

2、分別執行這兩條語句

  1. mysql> explain select * from t where a=1 and c=1; 
  2. mysql> explain select * from t where a=1 and b=1; 
優化體系--我是怎么計算mysql數據庫索引長度的?

3、思路

這里可以發現,前面兩個的區別主要是在于key_len上,我的理解是:

將組合索引想成書的一級目錄、二級目錄、三級目錄,如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的呢?

4、key_len的計算.

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(變長列)

所以從上面可以得出

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

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

5、創建新的測試表t2

創建一個t2表,數據結構如下

  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); 
優化體系--我是怎么計算mysql數據庫索引長度的?

6、計算key_len

  1. explain select * from t2 where name="001" and id=1; 
優化體系--我是怎么計算mysql數據庫索引長度的?

分析key_len=4+5*1+2=11,因為字段都是not null,int類型4個字節,varchar(5) 占用5個字符+2個字節,latin1編碼的表一個字符占1個字節,故varchar(5) 占用7個字節。

總結

因為MySQL具有查詢優化器,所以對where a=1 and c=1類型的查詢,字段順序沒有任何影響,查詢優化器會自動優化。where c=1 and a=1會被優化成where a=1 and c=1,但是建議還是使用where a=1 and c=1吧,便于理解以及查詢緩沖。

責任編輯:華軒 來源: 今日頭條
相關推薦

2018-06-26 15:58:06

數據庫MySQL索引優化

2011-03-08 08:49:55

MySQL優化單機

2011-03-03 17:56:52

MySQL數據庫優化

2010-06-04 11:28:05

MySQL數據庫

2011-04-20 16:35:26

優化MySQLNoSQL

2016-12-12 13:07:57

數據庫優化SQL

2010-05-21 12:15:52

2019-12-18 08:00:09

MySQL數據庫ORDER BY

2020-05-20 18:40:11

MySQL回表與索引數據庫

2013-01-04 10:00:12

MySQL數據庫數據庫查詢優化

2010-07-01 14:18:09

SQL Server數

2011-03-09 08:53:02

MySQL優化集群

2019-04-02 10:36:17

數據庫MySQL優化方法

2011-06-30 16:57:03

數據壓縮

2019-08-19 11:07:41

SQL數據庫優化

2011-07-06 14:12:20

MySQLPercona

2023-10-04 11:16:03

數據庫MySQL

2010-05-26 13:42:08

MySQL數據庫索引

2011-07-06 10:49:50

MySQL優化

2010-11-22 13:23:52

MySQL數據庫優化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本在线视频一区二区 | 欧美视频免费在线 | 老司机久久 | 欧美a级成人淫片免费看 | 久久久黄色| 天天干精品| 久久久久亚洲精品中文字幕 | 亚洲一区av在线 | 男女网站视频 | www免费视频 | 成人精品一区亚洲午夜久久久 | 日日骚网| 一区二区三区免费观看 | 国产精品九九九 | 成人免费视频一区二区 | 日韩一级不卡 | 中文字幕视频在线观看免费 | 免费成人高清 | 国产日韩欧美 | 国产高潮好爽受不了了夜色 | 久久99精品久久久久蜜桃tv | 亚洲播放一区 | 久久国内精品 | 日本一区二区电影 | 国产精品一区二区三区四区 | 欧美视频在线一区 | 久操国产| 成人亚洲 | 丝袜 亚洲 另类 欧美 综合 | 国产精品欧美一区喷水 | 国产一级在线 | 黄网站涩免费蜜桃网站 | 亚洲 欧美 日韩 在线 | 岛国一区| 91伊人网| 人妖av| 男女羞羞免费视频 | 在线看一区二区三区 | 国产网站在线播放 | 亚洲国产精选 | 国产精品久久久久久久久久久久久 |