MySQL 聯合索引與Where子句的最佳化 提高資料庫運行效率

來源:互聯網
上載者:User

網站系統上線至今,資料量已經不知不覺上到500M,近8W記錄了。涉及資料庫操作的基本都是變得很慢了,用的人都會覺得躁火~~然後把這個情況在群裡一貼,包括機器配置什麼的一說,馬上就有群友發話了,而且幫我確定了不是機器配置的問題,“深圳-槍手”熱心人他的機器512記憶體過百W的資料裡也跑得飛快,甚至跟那些幾W塊的機器一樣牛(吹過頭了),呵呵~~~

  在群友的分析指點下,嘗試把排序、條件等一個一個去除來做測試,結果發現問題就出在排序部分,去除排序的時候,執行時間由原來的48秒變成0.3x秒,這是個什麼檔次的變化呀~~看著這個結果我激動ing.....

  於是我把涉及排序的欄位組成一個聯合索引alter table xx add index indexname(x1,x2,x3),經過2分鐘建立新索引之後再執行同一個SQL語句,哇塞0.28S。。。。爽

  於是按照同樣的思路把其它幾個常用的SQL作了過些最佳化,效果馬上見效

  過了30分鐘再查slow sql記錄檔案,不好了,發現原來一個好好的SQL變得灰常慢了,神馬情況?

  幾經分析和測試原來就是因為添加了聯合索引的原因,而且這個SQL語句當中有個or,當把這個or改用union之後問題排除。

  這回又得出一個心得:寫SQL的時候千萬別一時就手,隨便寫個就OK,那會為以為帶來很嚴重的後果。

  再附上一段關於Where子句的執行順序:

  在用MySQL查詢資料庫的時候,串連了很多個用,發現非常慢。例如:

  SELECT ... WHERE p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1 AND p.products_id IN (472,474)

  這樣查詢需要20多秒,雖然在各個欄位上都建立了索引。用分析Explain SQL一分析,發現在第一次分析過程中就返回了幾萬條資料:

  WHERE p.languages_id = 1 ,然後再依次根據條件,縮小範圍。

  而我改變一下WHERE 欄位的位置之後,速度就有了明顯地提高:

  WHERE p.products_id IN (472,474) AND p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1

  這樣,第一次的條件是p.products_id IN (472,474),它返回的結果只有不到10條,接下來還要根據其它的條件來過濾,自然在速度上有了較大的提升。

  經過實踐發現,不要以為WHERE中的欄位順序無所謂,可以隨便放在哪,應該儘可能地第一次就過濾掉大部分無用的資料,只返回最小範圍的資料。

  希望能幫到有同樣遭遇的朋友。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.