中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL索引有哪些分類

發布時間:2021-08-12 17:17:39 來源:億速云 閱讀:334 作者:Leah 欄目:大數據

MySQL索引有哪些分類,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

 

1、分類

MySQL索引分為普通索引、唯一索引、主鍵索引、組合索引、全文索引。索引不會包含有null值的列,索引項可以為null(唯一索引、組合索引等),但是只要列中有null值就不會被包含在索引中。

(1)普通索引: create index index_name on table(column);

或者創建表時指定,create table(..., index index_name column);

(2)唯一索引: 類似普通索引,索引列的值必須唯一(可以為空,這點和主鍵索引不同)

create unique index index_name on table(column);或者創建表時指定unique index_name column

(3)主鍵索引: 特殊的唯一索引,不允許為空,只能有一個,一般是在建表時指定primary key(column)

(4)組合索引: 在多個字段上創建索引,遵循最左前綴原則。alter table t add index index_name(a,b,c);

(5)全文索引: 主要用來查找文本中的關鍵字,不是直接與索引中的值相比較,像是一個搜索引擎,配合match against使用,現在只有char,varchar,text上可以創建全文索引。

在數據量較大時,先將數據放在一張沒有全文索引的表里,然后再利用create index創建全文索引,比先生成全文索引再插入數據快很多。

 

2、何時使用索引

MySQL每次查詢只使用一個索引。與其說是“數據庫查詢只能用到一個索引”,倒不如說,和全表掃描比起來,去分析兩個索引B+樹更加耗費時間。所以where A=a and B=b這種查詢使用(A,B)的組合索引最佳,B+樹根據(A,B)來排序。

  1. 主鍵,unique字段;
  2. 和其他表做連接的字段需要加索引;
  3. 在where里使用>,≥,=,<,≤,is null和between等字段;
  4. 使用不以通配符開始的like,where A like 'China%';
  5. 聚集函數MIN(),MAX()中的字段;
  6. order by和group by字段;
 

3、何時不使用索引

  1. 表記錄太少;
  2. 數據重復且分布平均的字段(只有很少數據值的列);
  3. 經常插入、刪除、修改的表要減少索引;
  4. text,image等類型不應該建立索引,這些列的數據量大(假如text前10個字符唯一,也可以對text前10個字符建立索引);
  5. MySQL能估計出全表掃描比使用索引更快時,不使用索引;
 

4、索引何時失效

  1. 組合索引未使用最左前綴,例如組合索引(A,B),where B=b不會使用索引;
  2. like未使用最左前綴,where A like '%China';
  3. 搜索一個索引而在另一個索引上做order by,where A=a order by B,只使用A上的索引,因為查詢只使用一個索引 ;
  4. or會使索引失效。如果查詢字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效)
  5. 如果列類型是字符串,要使用引號。例如where A='China',否則索引失效(會進行類型轉換);
  6. 在索引列上的操作,函數(upper()等)、or、!=(<>)、not in等;
 

5、explain語句

MySQL索引有哪些分類  
MySQL索引有哪些分類  

type字段為All,未使用索引;為ref,使用索引

  • ALL: 全表掃描
  • index: 索引全掃描
  • range: 索引范圍掃描,常用語<,<=,>=,between等操作
  • ref: 使用非唯一索引掃描或唯一索引前綴掃描,返回單條記錄,常出現在關聯查詢中
  • eq_ref: 類似ref,區別在于使用的是唯一索引,使用主鍵的關聯查詢
  • const/system: 單條記錄,系統會把匹配行中的其他列作為常數處理,如主鍵或唯一索引查詢
  • null: MySQL不訪問任何表或索引,直接返回結果


看完上述內容,你們掌握MySQL索引有哪些分類的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄石市| 靖宇县| 礼泉县| 连云港市| 婺源县| 朝阳区| 阿合奇县| 祥云县| 抚顺县| 蓬溪县| 海兴县| 自贡市| 紫阳县| 鹿泉市| 宜都市| 隆昌县| 大英县| 武山县| 凤山市| 莫力| 临泽县| 宽城| 名山县| 垫江县| 宜丰县| 侯马市| 道孚县| 沂水县| 天祝| 阿拉善左旗| 大港区| 武定县| 丰城市| 方山县| 泸西县| 榆树市| 巧家县| 浮山县| 高州市| 临洮县| 榆中县|