Oracle Exists用法
(一) 用Oracle Exists替换DISTINCT:
@H_301_12@ 当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT。一般能够考虑用Oracle EXIST替换,Oracle Exists使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立即返回结果。 Oracle Exists用法
(一) 用Oracle Exists替换DISTINCT:
@H_301_12@ 当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT。一般能够考虑用Oracle EXIST替换,Oracle Exists使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立即返回结果。例: select * from emp_tax;
1: 内表必须要和外表连接。
select *
from emp_tax o
where exists (select *
from emp_tax i
where i.empno = o.empno
and i.empno < 0005);
2. exists 适合外表的结果集小的情况。因为exists是对外表作loop,每次loop再对那表进行查询。
当exists中的where后面条件为真的时候则把前面select的内容显示出来(外表的select).
in 是把外表和那表作hash join,而exists是对外表作loop,每次loop再对那表进行查询。 这样的话,in适合内外表都很大的情况,exists适合外表结果集很小的情况。