技巧收藏
1. SELECT 子句中避免使用 “*”
当你想在 SELECT 子句中列出所有的 COLUMN 时,使用动态 SQL 列引用 ‘*’ 是一个方便
的方法.不幸的是,这是一个非常低效的方法. 实际上,ORACLE 在解析的过程中, 会将“*” 依次
转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间.
2.使用 DECODE 函数来减少处理时间
使用 DECODE 函数可以避免重复扫描相同记录或重复连接相同的表. 例如:
Sql 代码
1. SELECTCOUNT(*),SUM(SAL)FROMEMPWHEREDEPT_NO=0020ANDEN
AMELIKE‘SMITH%’;
2. SELECTCOUNT(*),SUM(SAL)FROMEMPWHEREDEPT_NO=0030ANDENA
MELIKE‘SMITH%’;
你可以用 DECODE 函数高效地得到相同结果:
Sql 代码
1. SELECTCOUNT(DECODE(DEPT_NO,0020,’X’,NULL))D0020_COUNT,
2. COUNT(DECODE(DEPT_NO,0030,’X’,NULL))D0030_COUNT,
3. SUM(DECODE(DEPT_NO,0020,SAL,NULL))D0020_SAL,
4. SUM(DECODE(DEPT_NO,0030,SAL,NULL))D0030_SAL
5. FROMEMPWHEREENAMELIKE‘SMITH%’;
类似的,DECODE 函数也可以运用于 GROUP BY 和 ORDER BY 子句中.
3.删除重复记录
最高效的删除重复记录方法 ( 因为使用了 ROWID)
Sql 代码
1. DELETEFROMEMPEWHEREE.ROWID>(SELECTMIN(X.ROWID)FROMEMP
XWHEREX.EMP_NO=E.EMP_NO);
4. 用 TRUNCATE 替代 DELETE
当删除表中的记录时,在通常情况下,回滚段(rollback segments ) 用来存放可以被恢复的
信息,如果你没有 COMMIT 事务,ORACLE 会将数据恢复到删除之前的状态(准确地说是
恢复到执行删除命令之前的状况),而当运用 TRUNCATE 时, 回滚段不再存放任何可被恢复
的信息.当命令运行后,数据不能被恢复.因此很少的资源被调用,执行时间也会很短.
5.计算记录条数
和一般的观点相反, count(*) 比 count(1)稍快 ,当然如果可以通过索引检索,对索引列的
计数仍旧是最快的. 例如 COUNT(EMPNO)