資料庫優化的指導思路是首先寫出的SQL是優化器喜歡的,然後在排除爛的SQL的情況下就是,找瓶頸,資料庫吞吐量上不去或者查詢慢都是因為某一瓶頸的存在,從非常大的粒度來看,瓶頸可以分為五類:io內存CPU網路鎖。
當卡在某一瓶頸時,其他的資源就會被閑置,解決瓶頸或者用非瓶頸的資源做tradeoff達到總和的最大才是優化的正解,比如建索引就是以空間換時間的做法。
由於資料庫相對比較復雜,上下文有區別優化思路也會不一樣,所以離開上下文談具體的優化手段就是坑。
大部分開發人員會犯的錯誤是所謂的「錘子人」,也就是自己是錘子看什麼都像釘子,比如覺得慢就說要分區,覺得某種語句的寫法一定比另一種快而不考慮場景。
㈡ sql優化常用的幾種方法
sql優化常用的方法:適當的索引、僅索引相關數據、根據需求使用或避免臨時表等。
一、適當的索引
索引基本上是一種數據結構,有助於加速整個數據檢索過程。唯一索引是創建不重疊的數據列的索引。正確的索引可以更快地訪問資料庫,但是索引太多或沒有索引會導致錯誤的結果。IT培訓認為如果沒有索引,處理速度會變得非常慢。
SQL的功能介紹
1、SQL數據定義功能:能夠定義資料庫的三級模式結構,即外模式、全局模式和內模式結構。在SQL中,外模式又叫做視圖(View),全局模式簡稱模式(Schema),內模式由系統根據資料庫模式自動實現,一般無需用戶過問。
2、SQL數據操縱功能:包括對基本表和視圖的數據插入、刪除和修改,特別是具有很強的數據查詢功能。
3、SQL的數據控制功能:主要是對用戶的訪問許可權加以控制,以保證系統的安全性。