mysql聯(lián)合索引的使用規(guī)則
聯(lián)合索引又叫復合索引。對于復合索引:Mysql從左到右的使用索引中的字段,一個查詢可以只使用索引中的一部份,但只能是最左側部分。例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3種組合進行查找,但不支持 b,c進行查找 .當最左側字段是常量引用時,索引就十分有效。
從一道有趣的題目開始分析:
假設某個表有一個聯(lián)合索引(c1,c2,c3,c4)以下選項哪些字段使用了該索引:
A where c1=x and c2=x and c4>x and c3=x
B where c1=x and c2=x and c4=x order by c3
C where c1=x and c4= x group by c3,c2
D where c1=? and c5=? order by c2,c3
E where c1=? and c2=? and c5=? order by c2,c3
下面我們開始:
首先創(chuàng)建表:
CREATE TABLE t( c1 CHAR(1) not null, c2 CHAR(1) not null, c3 CHAR(1) not null, c4 CHAR(1) not null, c5 CHAR(1) not null )ENGINE myisam CHARSET UTF8;
有c1到c5 5個字段,特別說明一下 字段類型都是定長char(1)類型,并且非空,字符集是utf8(與計算索引使用字節(jié)數(shù)有關)
創(chuàng)建索引:
alter table t add index c1234(c1,c2,c3,c4);
插入2條數(shù)據(jù):insert into t VALUES('1','1','1','1','1'),('2','2','2','2','2')
使用MySql Explain開始分析題目結果:
A選項:


結果可以看出,c1,c2,c3,c4均使用到了該索引,而我們對A結果稍作更改:
將c2條件去掉后:

根據(jù)索引最左原則,c2字段沒有使用索引,c2之后的字段都不能使用索引。下面2圖我們對比下索引最左原則:

上圖結果顯示直接使用c3是全表查詢,無法使用該索引的,所以c3字段使用索引的前提是c1,c2兩字段均使用了索引。
即是索引的最左原則(左前綴原則)。
B選項:

key_len長度說明c1,c2字段用到了該索引,Extra顯示并沒有使用臨時表進行排序,說明排序是使用了索引的,但并沒有計算在key_len值中,也沒有起到連接c4的作用,說明索引到c3這里是斷掉的。
排序其實是利用聯(lián)合索引直接完成了的,即:使用了c1234聯(lián)合索引,就已經(jīng)使得c1下c2,c2下c3,c3下c4是有序的了,所以實際是排序利用了索引,c3字段并沒有使用該索引。(這段寫的時候總感覺有點別扭,不知道我理解的對不對,還有待更深層次的研究)
C選項:

使用group by 一般先生成臨時文件,再進行排序,但是字段順序為c2,c3時,并沒有用臨時表進行排序,而是利用索引排序好的;當group by字段為c3,c2時,由于與索引字段順序不一致,所以分組和排序并沒有利用到索引。
由key_len長度確定,只有c1一個字段使用了索引。
D選項:

order by 和group by 類似,字段順序與索引一致時,會使用索引排序;字段順序與索引不一致時,不使用索引。
由key_len長度確定,只有c1一個字段使用了索引。
E選項:

其實選項E的結果分析在上述ABCD的結果中都分析過了,這里只有c1,c2字段使用了該索引。
綜上所述問題答案:
A:四個字段均使用了該索引
B:c1,c2字段使用了該索引
C:c1字段使用該索引
D:c1字段使用該索引
E:c1,c2字段使用了該索引
總結:
索引的最左原則(左前綴原則),如(c1,c2,c3,c4....cN)的聯(lián)合索引,where 條件按照索引建立的字段順序來使用(不代表and條件必須按照順序來寫),如果中間某列沒有條件,或使用like會導致后面的列不能使用索引。
索引也能用于分組和排序,分組要先排序,在計算平均值等等。所以在分組和排序中,如果字段順序可以按照索引的字段順序,即可利用索引的有序特性。
到此這篇關于mysql聯(lián)合索引的使用規(guī)則的文章就介紹到這了,更多相關mysql聯(lián)合索引內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Sphinx/MySQL 協(xié)議支持與SphinxQL應用實例
Sphinx/MySQL 協(xié)議支持與SphinxQL應用例子,供大家學習參考2013-02-02
mysql之key和index的區(qū)別及創(chuàng)建刪除索引方式
這篇文章主要介紹了mysql之key和index的區(qū)別及創(chuàng)建刪除索引方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
MySQL使用索引合并(Index?Merge)提高查詢效率
本文介紹了索引合并(Index?Merge)的實現(xiàn)原理、場景約束與通過案例驗證的優(yōu)缺點,在實際使用中,當查詢條件列較多且無法使用聯(lián)合索引時,就可以考慮使用索引合并,利用多個索引加速查詢,但要注意,索引合并并非在任何場景下均具有較好的效果,需要結合具體情況選擇2024-07-07
MySql基本查詢之表的增刪查改+聚合函數(shù)案例詳解
本文詳解SQL的CURD操作INSERT用于數(shù)據(jù)插入(單行/多行及沖突處理),SELECT實現(xiàn)數(shù)據(jù)檢索(列選擇、條件過濾、排序分頁),UPDATE修改數(shù)據(jù),DELETE刪除數(shù)據(jù)并對比TRUNCATE,涵蓋聚合函數(shù)、GROUP BY分組統(tǒng)計及經(jīng)典練習題,強調(diào)操作注意事項與執(zhí)行順序,感興趣的朋友一起看看吧2025-07-07
從MySQL5.7平滑升級到MySQL8.0數(shù)據(jù)庫的最佳實踐教程
這篇文章主要給大家介紹了關于從MySQL5.7平滑升級到MySQL8.0數(shù)據(jù)庫的最佳實踐,升級MySQL版本需要進行一系列操作,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2024-07-07
Mysql如何導出篩選數(shù)據(jù)并導出帶表頭的csv文件
這篇文章主要介紹了Mysql如何導出篩選數(shù)據(jù)并導出帶表頭的csv文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

