删除重复记录
最高效的删除重复记录方法 ( 因为使用了ROWID)
DELETEFROMEMPE
WHEREEROWID>(SELECTMIN(XROWID)
FROMEMPX
WHEREXEMP_NO=EEMP_NO);
用TRUNCATE替代DELETE
当删除表中的记录时在通常情况下 回滚段(rollback segments ) 用来存放可以被恢复的信息 如果你没有COMMIT事务ORACLE会将数据恢复到删除之前的状态(准确地说是恢复到执行删除命令之前的状况)
而当运用TRUNCATE时 回滚段不再存放任何可被恢复的信息当命令运行后数据不能被恢复因此很少的资源被调用执行时间也会很短
(译者按 TRUNCATE只在删除全表适用TRUNCATE是DDL不是DML)
尽量多使用COMMIT
只要有可能在程序中尽量多使用COMMIT 这样程序的性能得到提高需求也会因为COMMIT所释放的资源而减少COMMIT所释放的资源
a 回滚段上用于恢复数据的信息
b 被程序语句获得的锁
c redo log buffer 中的空间
d ORACLE为管理上述种资源中的内部花费
(译者按 在使用COMMIT时必须要注意到事务的完整性现实中效率和事务完整性往往是鱼和熊掌不可得兼)
计算记录条数
和一般的观点相反 count(*) 比count()稍快 当然如果可以通过索引检索对索引列的计数仍旧是最快的 例如 COUNT(EMPNO)
(译者按 在CSDN论坛中曾经对此有过相当热烈的讨论 作者的观点并不十分准确通过实际的测试上述三种方法并没有显着的性能差别)
用Where子句替换HAVING子句
避免使用HAVING子句 HAVING 只会在检索出所有记录之后才对结果集进行过滤 这个处理需要排序总计等操作 如果能通过WHERE子句限制记录的数目那就能减少这方面的开销
例如
低效
SELECTREGIONAVG(LOG_SIZE)
FROMLOCATION
GROUPBYREGION
HAVINGREGIONREGION!=SYDNEY
ANDREGION!=PERTH
高效
SELECTREGIONAVG(LOG_SIZE)
FROMLOCATION
WHEREREGIONREGION!=SYDNEY
ANDREGION!=PERTH
GROUPBYREGION
(译者按 HAVING 中的条件一般用于对一些集合函数的比较如COUNT() 等等 除此而外一般的条件应该写在WHERE子句中)