關於mysql執行效率最佳化注意事項及要點

來源:互聯網
上載者:User

標籤:style   ar   io   color   os   使用   sp   on   檔案   

1. SQL最佳化的原則是:將一次操作需要讀取的BLOCK數減到最低,即在最短的時間達到最大的資料輸送量。 調整不良SQL通常可以從以下幾點切入: ? 檢查不良的SQL,考慮其寫法是否還有可最佳化內容 ? 檢查子查詢 考慮SQL子查詢是否可以用簡單串連的方式進行重新書寫 ? 檢查最佳化索引的使用 ? 考慮資料庫的最佳化器 2. 避免出現SELECT * FROM table 語句,要明確查出的欄位。 3. 在一個SQL語句中,如果一個where條件過濾的資料庫記錄越多,定位越準確,則該where條件越應該前移。 4. 查詢時儘可能使用索引覆蓋。即對SELECT的欄位建立複合索引,這樣查詢時只進行索引掃描,不讀取資料區塊。 5. 在判斷有無合格記錄時建議不要用SELECT COUNT (*)和select top 1 語句。 6. 使用內層限定原則,在拼字SQL語句時,將查詢條件分解、分類,並盡量在SQL語句的最裡層進行限定,以減少資料的處理量。 7. 應絕對避免在order by子句中使用運算式。 8. 如果需要從關聯表讀資料,關聯的表一般不要超過7個。 9. 小心使用 IN 和 OR,需要注意In集合中的資料量。建議集合中的資料不超過200個。 10. <> 用 < 、 > 代替,>用>=代替,<用<=代替,這樣可以有效利用索引。 11. 在查詢時盡量減少對多餘資料的讀取包括多餘的列與多餘的行。 12. 對於複合索引要注意,例如在建立複合索引時列的順序是F1,F2,F3,則在where或order by子句中這些欄位出現的順序要與建立索引時的欄位順序一致,且必須包含第一列。只能是F1或F1,F2或F1,F2,F3。否則不會用到該索引。 13. 多表關聯查詢時,寫法必須遵循以下原則,這樣做有利於建立索引,提高查詢效率。格式如下select sum(table1.je) from table1 table1, table2 table2, table3 table3 where (table1的等值條件(=)) and (table1的非等值條件) and (table2與table1的關聯條件) and (table2的等值條件) and (table2的非等值條件) and (table3與table2的關聯條件) and (table3的等值條件) and (table3的非等值條件)。 注:關於多表查詢時from 後面表的出現順序對效率的影響還有待研究。 14. 子查詢問題。對於能用串連方式或者視圖方式實現的功能,不要用子查詢。例如:select name from customer where customer_id in ( select customer_id from order where money>1000)。應該用如下語句代替:select name from customer inner join order on customer.customer_id=order.customer_id where order.money>100。 15. 在WHERE 子句中,避免對列的四則運算,特別是where 條件的左邊,嚴禁使用運算與函數對列進行處理。比如有些地方 substring 可以用like代替。 16. 如果在語句中有not in(in)操作,應考慮用not exists(exists)來重寫,最好的辦法是使用外串連實現。 17. 對一個業務過程的處理,應該使事物的開始與結束之間的時間間隔越短越好,原則上做到資料庫的讀操作在前面完成,資料庫寫操作在後面完成,避免交叉。 18. 請小心不要對過多的列使用列函數和order by,group by等,謹慎使用disti軟體開發t。 19. 用union all 代替 union,資料庫執行union操作,首先先分別執行union兩端的查詢,將其放在暫存資料表中,然後在對其進行排序,過濾重複的記錄。 當已知的商務邏輯決定query A和query B中不會有重複記錄時,應該用union all代替union,以提高查詢效率。資料更新的效率 1. 在一個事物中,對同一個表的多個insert語句應該集中在一起執行。 2. 在一個業務過程中,盡量的使insert,update,delete語句在業務結束前執行,以減少死結的可能性。 資料庫物理規劃的效率 為了避免I/O的衝突,我們在設計資料庫物理規劃時應該遵循幾條基本的原則(以ORACLE舉例): ?? table和index分離:table和index應該分別放在不同的tablespace中。 ?? Rollback Segment的分離:Rollback Segment應該放在獨立的Tablespace中。 ?? System Tablespace的分離:System Tablespace中不允許放置任何使用者的object。(mssql中primary filegroup中不允許放置任何使用者的object) ?? Temp Tablesace的分離:建立單獨的Temp Tablespace,並為每個user指定default Temp Tablespace ??避免片段:但segment中出現大量的片段時,會導致讀資料時需要訪問的block數量的增加。對經常發生DML操作的segemeng來說,片段是不能完全避免的。所以,我們應該將經常做DML操作的表和很少發生變化的表分離在不同的Tablespace中。 當我們遵循了以上原則後,仍然發現有I/O衝突存在,我們可以用資料分離的方法來解決。 ?? 串連Table的分離:在實際應用中經常做串連查詢的Table,可以將其分離在不同的Taclespace中,以減少I/O衝突。 ?? 使用分區:對資料量很大的Table和Index使用分區,放在不同的Tablespace中。 在實際的實體儲存體中,建議使用RAID。記錄檔應放在單獨的磁碟中。

關於mysql執行效率最佳化注意事項及要點

聯繫我們

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