??????? mysql中 myisam雏节,innodb默認(rèn)使用的是 Btree索引氢伟,至于btree的數(shù)據(jù)結(jié)構(gòu)是怎樣的都不重要酷宵,只需要知道結(jié)果,既然是索引那這個數(shù)據(jù)結(jié)構(gòu)最后是排好序器虾;就像新華字典他的目錄就是按照a,b,c..這樣排好序的讯嫂;所以你在找東西的時(shí)候才快,比如你找 “中” 這個字的解釋兆沙,你肯定就會定位到目錄的 z 開頭部分欧芽;組合索引可以這樣理解,比如(a,b,c)葛圃,abc都是排好序的千扔,在任意一段a的下面b都是排好序的憎妙,任何一段b下面c都是排好序的;
??????? 組合索引的生效原則是? 從前往后依次使用生效曲楚,如果中間某個索引沒有使用尚氛,那么斷點(diǎn)前面的索引部分起作用,斷點(diǎn)后面的索引沒有起作用洞渤;比如
where a=3 and b=45 and c=5 .... 這種三個索引順序使用中間沒有斷點(diǎn)阅嘶,全部發(fā)揮作用;
where a=3 and c=5... 這種情況下b就是斷點(diǎn)载迄,a發(fā)揮了效果讯柔,c沒有效果
where b=3 and c=4... 這種情況下a就是斷點(diǎn),在a后面的索引都沒有發(fā)揮作用护昧,這種寫法聯(lián)合索引沒有發(fā)揮任何效果魂迄;
where b=45 and a=3 and c=5 .... 這個跟第一個一樣,全部發(fā)揮作用惋耙,abc只要用上了就行捣炬,跟寫的順序無關(guān)
a,b,c) 三個列上加了聯(lián)合索引(是聯(lián)合索引 不是在每個列上單獨(dú)加索引)還需注意,? (a,b,c)多列索引和 (a,c,b)是不一樣的绽榛;
分析幾個實(shí)際例子來加強(qiáng)理解:
(0) select * from mytable where a=3 and b=5 and c=4; abc三個索引都在where條件里面用到了湿酸,而且都發(fā)揮了作用
(1) select * from mytable where c=4 and b=6 and a=3; 這條語句列出來只想說明 mysql沒有那么笨,where里面的條件順序在查詢之前會被mysql自動優(yōu)化灭美,效果跟上一句一樣
(2) select * from mytable where a=3 and c=7; a用到索引推溃,b沒有用,所以c是沒有用到索引效果的
(3) select * from mytable where a=3 and b>7 and c=3; a用到了届腐,b也用到了铁坎,c沒有用到,這個地方b是范圍值犁苏,也算斷點(diǎn)硬萍,只不過自身用到了索引
(4) select * from mytable where b=3 and c=4; 因?yàn)閍索引沒有使用,所以這里 bc都沒有用上索引效果
(5) select * from mytable where a>4 and b=7 and c=9; a用到了 b沒有使用围详,c沒有使用
(6) select * from mytable where a=3 order by b; a用到了索引朴乖,b在結(jié)果排序中也用到了索引的效果,前面說了短曾,a下面任意一段的b是排好序的
(7) select * from mytable where a=3 order by c; a用到了索引寒砖,但是這個地方c沒有發(fā)揮排序效果,因?yàn)橹虚g斷點(diǎn)了嫉拐,使用 explain 可以看到 filesort
(8) select * from mytable where b=3 order by a; b沒有用到索引哩都,排序中a也沒有發(fā)揮索引效果