ORACLE SQL性能优化系列(七)_Oracle数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

ORACLE SQL性能优化系列(七)

作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0

黑客防线网安网讯:12.       尽量多使用COMMIT 只要有可能,在程序中尽量多使用COMMIT, 这样程序的性能得到提高,需求也会因为COMMIT所释放的资源而减少:  COMMIT所释放的资源: a.       回滚段上用于恢复数据的...

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 REGIONAVG(LOG_SIZE)      FROM LOCATION      GROUP BY REGION      HAVING REGION REGION != ‘SYDNEY’      AND REGION != ‘PERTH’      高效      SELECT REGIONAVG(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;

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-12154-1.html
网站维护教程更新时间:2012-03-23 00:33:14  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer