成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL:聯合索引與Where子句的優化

數據庫 MySQL 數據庫運維
經過實踐發現,不要以為WHERE中的字段順序無所謂,可以隨便放在哪,應該盡可能地第一次就過濾掉大部分無用的數據,只返回最小范圍的數據。

本網站系統上線至今,數據量已經不知不覺上到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查詢數據庫的時候,連接了很多個用,發現非常慢。例如:

  1. 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 字段的位置之后,速度就有了明顯地提高:

  1. WHERE p.products_id IN (472,474) AND 
  2. 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中的字段順序無所謂,可以隨便放在哪,應該盡可能地***次就過濾掉大部分無用的數據,只返回最小范圍的數據。

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

 

【編輯推薦】

  1. MySQL中創建及優化索引組織結構的思路
  2. 微博 請問你是怎么優化數據庫的?
  3. MySQL技巧:結合相關參數 做好Limit優化
  4. MySQL數據庫的優化(下)MySQL數據庫的高可用架構方案
  5. MySQL數據庫的優化(上)單機MySQL數據庫的優化
責任編輯:艾婧 來源: 5ishare.com
相關推薦

2010-09-26 09:50:36

SQL Where子句

2010-09-26 14:46:19

SQL WHERE子句

2009-09-10 17:30:15

LINQ Where子

2009-11-19 14:59:25

Oracle Wher

2017-07-25 12:07:14

MySQL索引SQL

2024-10-09 23:32:50

2021-07-26 18:23:23

SQL策略優化

2024-09-19 08:09:37

MySQL索引數據庫

2020-10-19 19:45:58

MySQL數據庫優化

2010-06-04 11:28:05

MySQL數據庫

2024-02-27 09:12:24

PostgreSQL數據庫查詢WHERE 子句

2018-06-07 08:54:01

MySQL性能優化索引

2011-07-28 16:16:27

MySQL數據庫索引ORDER BY

2010-05-12 11:14:25

MySQL SQL優化

2010-10-12 16:44:36

MySQL語句

2018-04-09 14:25:06

數據庫MySQL索引

2024-04-17 12:58:15

MySQL索引數據庫

2023-11-07 07:50:55

LIMIT子句下推優化

2023-10-23 09:19:47

PawSQL數據庫

2018-01-23 10:29:50

主搜索店鋪搜索
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费看日韩视频 | 日韩在线观看中文字幕 | 国产高清视频一区二区 | 视频在线日韩 | 99久久精品国产一区二区三区 | 日本一区二区高清视频 | 日本三级全黄三级三级三级口周 | 欧美精品综合在线 | 日本黄色片免费在线观看 | 日韩三级在线观看 | 伊人色综合久久天天五月婷 | 亚洲一二三区在线观看 | 国产精品美女久久久久aⅴ国产馆 | 亚洲精品久久久一区二区三区 | 亚洲免费在线 | 色网在线播放 | 蜜臀久久99精品久久久久野外 | 久久av一区二区三区 | 欧美一级久久 | 久久久久久久久国产成人免费 | 亚洲国产精品久久久久秋霞不卡 | wwwxx在线观看 | 久久精品亚洲精品国产欧美 | 国产婷婷综合 | 国产精品精品久久久久久 | 久久久久久久亚洲精品 | 五月婷婷 六月丁香 | 国产视频福利一区 | 男人天堂av网站 | 日日干天天操 | 国产欧美精品 | 久久久久久国产精品免费 | 日韩伦理一区二区 | 99久久久无码国产精品 | 久久久久国产一区二区三区四区 | 免费视频一区二区三区在线观看 | 精品久久久久久久久久久久久久久久久 | 中文字幕国产一区 | 激情免费视频 | 久久久久国产精品一区二区 | 欧美日韩在线免费观看 |