国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

ORACLE SQL性能優化系列(七)

2024-08-29 13:33:00
字體:
來源:轉載
供稿:網友
12.       盡量多使用COMMIT只要有可能,在程序中盡量多使用COMMIT, 這樣程序的性能得到提高,需求也會因為COMMIT所釋放的資源而減少: COMMIT所釋放的資源:a.       回滾段上用于恢復數據的信息.b.       被程序語句獲得的鎖c.       redo log buffer 中的空間d.       Oracle為治理上述3種資源中的內部花費(譯者按: 在使用COMMIT時必須要注重到事務的完整性,現實中效率和事務完整性往往是魚和熊掌不可得兼)13.       計算記錄條數     和一般的觀點相反, count(*) 比count(1)稍快 , 當然假如可以通過索引檢索,對索引列的計數仍然是最快的. 例如 COUNT(EMPNO)
(譯者按: 在CSDN論壇中,曾經對此有過相當熱烈的討論, 作者的觀點并不十分準確,通過實際的測試,上述三種方法并沒有顯著的性能差別)
14.       用Where子句替換HAVING子句     避免使用HAVING子句, HAVING 只會在檢索出所有記錄之后才對結果集進行過濾. 這個處理需要排序,總計等操作. 假如能通過WHERE子句限制記錄的數目,那就能減少這方面的開銷.
例如:
     低效:     SELECT REGION,AVG(LOG_SIZE)     FROM LOCATION     GROUP BY REGION     HAVING REGION REGION != ‘SYDNEY’     AND REGION != ‘PERTH’     高效     SELECT REGION,AVG(LOG_SIZE)     FROM LOCATION     WHERE REGION REGION != ‘SYDNEY’     AND REGION != ‘PERTH’     GROUP BY REGION(譯者按: HAVING 中的條件一般用于對一些集合函數的比較,如COUNT() 等等. 除此而外,一般的條件應該寫在WHERE子句中)15.       減少對表的查詢
在含有子查詢的SQL語句中,要非凡注重減少對表的查詢.例如:
     低效          SELECT TAB_NAME          FROM TABLES          WHERE TAB_NAME = ( SELECT TAB_NAME                                 FROM TAB_COLUMNS                                WHERE VERSION = 604)          AND DB_VER= ( SELECT DB_VER                            FROM TAB_COLUMNS                           WHERE VERSION = 604)     高效          SELECT TAB_NAME          FROM TABLES          WHERE  (TAB_NAME,DB_VER) = ( SELECT TAB_NAME,DB_VER)                   FROM TAB_COLUMNS                   WHERE VERSION = 604)     Update 多個Column 例子:     低效:

           UPDATE EMP           SET EMP_CAT = (SELECT MAX(CATEGORY) FROM EMP_CATEGORIES),              SAL_RANGE = (SELECT MAX(SAL_RANGE) FROM EMP_CATEGORIES)           WHERE EMP_DEPT = 0020;    高效:           UPDATE EMP           SET (EMP_CAT, SAL_RANGE) = (SELECT MAX(CATEGORY) , MAX(SAL_RANGE) FROM EMP_CATEGORIES)           WHERE EMP_DEPT = 0020;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鲁甸县| 新泰市| 南宁市| 凤山市| 吉安市| 桐乡市| 朝阳县| 洛扎县| 景德镇市| 文成县| 琼结县| 沁水县| 兴业县| 兴仁县| 神木县| 绵竹市| 荔波县| 阿勒泰市| 桐乡市| 泰安市| 会昌县| 库尔勒市| 嘉鱼县| 凯里市| 广州市| 区。| 安义县| 大埔县| 罗城| 陵水| 青铜峡市| 顺平县| 秦皇岛市| 南开区| 富顺县| 铜鼓县| 石嘴山市| 石家庄市| 广州市| 莱芜市| 盐边县|