MySQL最佳化--where條件欄位的順序對效率的影響 (02)

來源:互聯網
上載者:User

標籤:

    學生表 Student

id(編號) name(名字) age(年齡) height(身高)
1 Tommy 26 170
2 Jerry 23 180
3 Frank 30 160

 

 

 

   如表所示,這裡只是呈現了3條資料,我們這裡假設有1萬條資料,

   查詢年齡25歲以上,身高170以上的全部學生

   Select * from Student where age > 25 and height > 170;//正常情況下可以這麼寫,

假設1:年齡在25歲以上的有8000個學生,而身高170以上的只有10個學生,

   上述的SQL的執行順序和查詢的行數應該是:

   1.先查詢年齡25歲以上的學生,結果有8000條記錄,

   2.再查詢身高170以上的學生,就得在8000條結果裡再次判斷,最壞的可以遍曆8000次左右,這效率較低

   假如更改上述SQL語句where條件欄位的順序,如下:

    Select * from Student where height > 170 and age > 25;

         那麼結果將是:

          1.首先是查詢出身高170以上的學生,結果只有10個;

          2.然後再在這10個結果中查詢出年齡大於25歲的學生,這樣遍曆的次數一下子就減少了很多很多

  總結:所以,千萬不要以為where語句中欄位的順序可以隨便亂寫,應該結合具體情況來安排好順序,以使效率更高,

          當然,如果想效率進一步提高,應該在這兩個欄位上建立索引 (題外: 索引的建立以及 什麼條件下索引才會被調用)

MySQL最佳化--where條件欄位的順序對效率的影響 (02)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.