亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

多列索引生效規則

發布時間:2020-07-13 18:25:18 來源:網絡 閱讀:737 作者:Abigale2018 欄目:數據庫

mysql中 myisam,innodb默認使用的是 Btree索引,至于btree的數據結構是怎樣的都不重要,
只需要知道結果,既然是索引那這個數據結構最后是排好序;就像新華字典他的目錄就是按照a,b,c..這樣排好序的;
所以你在找東西的時候才快,比如你找 “中” 這個字的解釋,你肯定就會定位到目錄的 z 開頭部分;

組合索引可以這樣理解,比如(a,b,c),abc都是排好序的,在任意一段a的下面b都是排好序的,任何一段b下面c都是排好序的;

多列索引生效規則
組合索引的生效原則是  從前往后依次使用生效,如果中間某個索引沒有使用,那么斷點前面的索引部分起作用,斷點后面的索引沒有起作用;
比如

where a=3 and b=45 and c=5 .... 這種三個索引順序使用中間沒有斷點,全部發揮作用;where a=3 and c=5... 這種情況下b就是斷點,a發揮了效果,c沒有效果where b=3 and c=4... 這種情況下a就是斷點,在a后面的索引都沒有發揮作用,這種寫法聯合索引沒有發揮任何效果;where b=45 and a=3 and c=5 .... 這個跟第一個一樣,全部發揮作用,abc只要用上了就行,跟寫的順序無關

 


(a,b,c) 三個列上加了聯合索引(是聯合索引 不是在每個列上單獨加索引)

還需注意,  (a,b,c)多列索引和 (a,c,b)是不一樣的,看上面的圖也看得出來關系順序是不一樣的;
分析幾個實際例子來加強理解;
分析句子中使用的索引情況

多列索引生效規則

(0)    select * from mytable where a=3 and b=5 and c=4;
abc三個索引都在where條件里面用到了,而且都發揮了作用
(1)    select * from mytable where  c=4 and b=6 and a=3;
這條語句列出來只想說明 mysql沒有那么笨,where里面的條件順序在查詢之前會被mysql自動優化,效果跟上一句一樣
(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是范圍值,也算斷點,只不過自身用到了索引
(4)    select * from mytable where b=3 and c=4;
因為a索引沒有使用,所以這里 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在結果排序中也用到了索引的效果,前面說了,a下面任意一段的b是排好序的
(7)    select * from mytable where a=3 order by c;
a用到了索引,但是這個地方c沒有發揮排序效果,因為中間斷點了,使用 explain 可以看到 filesort
(8)    select * from mytable where b=3 order by a;
b沒有用到索引,排序中a也沒有發揮索引效果


向AI問一下細節

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

AI

绥芬河市| 资源县| 武强县| 崇明县| 仪陇县| 远安县| 宝兴县| 赣州市| 克山县| 临猗县| 昌吉市| 雷山县| 绥滨县| 利津县| 淮滨县| 射洪县| 岐山县| 玛纳斯县| 句容市| 济南市| 武宣县| 介休市| 瓦房店市| 镇赉县| 永济市| 云南省| 宁乡县| 镇原县| 全州县| 保定市| 景泰县| 西峡县| 新乐市| 九龙县| 高尔夫| 玉山县| 酒泉市| 富蕴县| 寻乌县| 蓬莱市| 罗山县|