oracle的sql最佳化

來源:互聯網
上載者:User

1.能用oracle內建函數,或者用他的函數可以實現的效果,盡量用oracle的函數,因為他的函數的演算法和實現函數的語言都是效率非常高的,一般情況下比我們寫的要高效。

2. sql的關鍵字都大寫,因為oracle 再執行sql時,會把所有的sql 轉換為大寫來執行

3.select 句子中最好不要出現* ,要寫具體的列名,不然 oracle會一次解析每個欄位,費時。

4.from 的表,如果是一張或者兩張表,把條數最少的放在後面,如果是三張以上,把和其他有交叉的表的放在後面,所謂交叉,就是和其他表有關聯的的意思,因為oracle的掃描是從下網上從右往左,這樣 的結果是可以盡量的少掃描表,

5.where 把可以過濾掉多條資料的條件往後放,一次類推

6.重複資料刪除記錄的最好辦法是用rowid

7.使用decode函數減少 處理時間

8.用truncate table表明 代替delete from表名,因為第一個會刪除表所對應的資料表空間

9.用where過濾,少用having過濾

10.使用表的別名也可以提高效率

11.用 EXISTS 替代 IN 、用 NOT EXISTS 替代 NOT IN :

12.使用索引來提高查詢效率,但是索引建立的時候很有將就,並不是每個欄位都建立,那樣反而會降低效率

13.用 EXISTS 替換 DISTINCT

14.避免在索引上使用計算那些函數

15.用>= 來代替> ,因為有個確切的邊線,可以讓oracle跟好的確定邊線

16.避免在索引列上用not ,因為這回讓索引失效,也要避免使用is null ,is not null 操作

17.用union來代替 or 操作,如果可以的話

18.用in 代替or ,如果可以的話

相關文章

聯繫我們

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