提示处理是在ORACLE产生的SQL分析执行路径不满意的情况下要用到的。它可以对SQL进行以下方
面的提示
目标方面的提示:
COST(按成本优化)
RULE(按规则优化)
CHOOSE(缺省)(ORACLE自动选择成本或规则进行优化)
SELECT EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='SCOTT';
ALL_ROWS(所有的行尽快返回)
SELECT EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='SCOTT';
FIRST_ROWS(第一行数据尽快返回)
select *
from xxx
where xxx;
select *
from xxx
where xxx
优化器提示:用它的目的是提高SQL语句的响应时间,快速的先返回 n 行。
访问路径的提示
FULL: 执行全表扫描
ROID: 根据ROWID进行扫描
INDEX: 根据某个索引进行扫描
select * from emp where deptno=200 and sal>300;
如果写了多个,则ORACLE自动选择最优的哪个
select * from emp where deptno=200 and sal>300;
INDEX_JOIN: 如果所选的字段都是索引字段(是几个索引的),那么可以通过索引连接就可访问到数据,而不需要访问
表的数据。
select deptno,sal from emp
where deptno=20;
INDEX_FFS: 执行快速全索引扫描
select count(*) from emp;
NO_INDEX: 指定不使用哪些索引
select * from emp where deptno=200
and sal>300;
AND_EQUAL: 指定合并两个或以上索引检索的结果(交集),最多不能超过5个
执行方法的提示:
USE_NL(使用NESTED LOOPS方式联合)
USE_MERGE(使用MERGE join方式联合)
USE_HASH(使用HASH join方式联合)
根据表出现在FROM中的顺序,ORDERED使ORACLE依此顺序对其连接.
例如:
SELECT A.COL1,B.COL2,C.COL3 FROM TABLE1 A,TABLE2 B,TABLE3 C
WHERE A.COL1=B.COL1 AND B.COL1=C.COL1;
将指定表与嵌套的连接的行源进行连接,并把指定表作为内部表.
例如:
SELECT BSDPTMS.DPT_NO,BSEMPMS.EMP_NO,BSEMPMS.EMP_NAM
FROM BSEMPMS,BSDPTMS WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO;
将指定的表与其他行源通过合并排序连接方式连接起来.
例如:
SELECT * FROM BSEMPMS,BSDPTMS
WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO;
将指定的表与其他行源通过哈希连接方式连接起来.
例如:
SELECT * FROM BSEMPMS,BSDPTMS
WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO;
其它高级提示(如并行处理等等)
ORACLE的提示功能是比较强的功能,也是比较复杂的应用,并且提示只是给ORACLE执行的一个建议,
有时如果出于成本方面的考虑ORACLE也可能不会按提示进行。根据实践应用,一般不建议开发人员应用ORACLE提示,
因为各个数据库及服务器性能情况不一样,很可能一个地方性能提升了,但另一个地方却下降了,
ORACLE在SQL执行分析方面已经比较成熟,如果分析执行的路径不对首先应在数据库结构(主要是索引)、
服务器当前性能(共享内存、磁盘文件碎片)、数据库对象(表、索引)统计信息是否正确这几方面分析。