程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle sql 性能優化二

Oracle sql 性能優化二

編輯:Oracle數據庫基礎

1.select 子句中避免使用'*'

  當你想在SELECT子句中列出所有的COLUMN時,使用動態SQL列引用 ‘*’ 是一個方便的方法.不幸的是,這是一個非常低效的方法. 實際上,Oracle在解析的過程中, 會將’*’ 依次轉換成所有的列名, 這個工作是通過查詢數據字典完成的, 這意味著將耗費更多的時間.

2.減少訪問數據庫的次數

   當執行每條SQL語句時, Oracle在內部執行了許多工作: 解析SQL語句, 估算索引的利用率, 綁定變量 , 讀數據塊等等. 由此可見, 減少訪問數據庫的次數 , 就能實際上減少Oracle的工作量.

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

  使用DECODE函數可以避免重復掃描相同記錄或重復連接相同的表.

例如:

SELECT COUNT(*),SUM(SAL)FROM EMP WHERE DEPT_NO = 0020 AND ENAME LIKE ‘SMITH%’;

SELECT COUNT(*),SUM(SAL) FROM EMP WHERE DEPT_NO = 0030 AND ENAME LIKE ‘SMITH%’;

用DECODE函數高效地得到相同結果

SELECT COUNT(DECODE(DEPT_NO,0020,’X’,NULL)) D0020_COUNT,COUNT(DECODE(DEPT_NO,0030,’X’,NULL)) D0030_COUNT,SUM(DECODE(DEPT_NO,0020,SAL,NULL)) D0020_SAL,SUM(DECODE(DEPT_NO,0030,SAL,NULL)) D0030_SAL FROM EMP WHERE ENAME LIKE ‘SMITH%’;

類似的,DECODE函數也可以運用於GROUP BY 和ORDER BY子句中.

4. 用TRUNCATE替代DELETE
   當刪除表中的記錄時,在通常情況下, 回滾段(rollback segments ) 用來存放可以被恢復的信息. 如果你沒有COMMIT事務,Oracle會將數據恢復到刪除之前的狀態(准確地說是恢復到執行刪除命令之前的狀況)。而當運用TRUNCATE時, 回滾段不再存放任何可被恢復的信息.當命令運行後,數據不能被恢復.因此很少的資源被調用,執行時間也會很短.(TRUNCATE只在刪除全表適用,TRUNCATE是DDL不是DML)


5.盡量多使用commit 
  只要有可能,在程序中盡量多使用COMMIT, 這樣程序的性能得到提高,需求也會因為COMMIT所釋放的資源而減少.COMMIT所釋放的資源:

a.回滾段上用於恢復數據的信息.

b.被程序語句獲得的鎖

c.redo log buffer 中的空間

d.Oracle為管理上述3種資源中的內部花費.

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved