先看下面的例子:Oracle中兩個系統表.emp,dept.example:
1:not exists(not in)
not exists:
這條語句返回select * from scott.dept d where e.deptno=d.deptno and d.deptno=10條件滿足的結果集.也就是說,
-
返回的結果集中不存在d.deptno=10結果集的記錄,即emp表中沒有dept表中d.deptno=10的記錄.
SQL> select empno,ename,deptno from scott.emp e where not exists(select * from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7369 SMITH 20
7499 ALLEN 30
7521 WARD 30
7566 JONES 20
7654 MARTIN 30
7698 BLAKE 30
7788 SCOTT 20
7844 TURNER 30
7876 ADAMS 20
7900 JAMES 30
7902 FORD 20
11 rows selected
not in:
第一個where條件必須給定字段(deptno), 第二個sql語句中,必須明確給定要查詢的字段是哪個(deptno).
SQL> select empno,ename,deptno from scott.emp e where deptno not in(select deptno from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7369 SMITH 20
7499 ALLEN 30
7521 WARD 30
7566 JONES 20
7654 MARTIN 30
7698 BLAKE 30
7788 SCOTT 20
7844 TURNER 30
7876 ADAMS 20
7900 JAMES 30
7902 FORD 20
11 rows selected
2: exists(in)
exists:
這條語句返回select * from scott.dept d where e.deptno=d.deptno and d.deptno=10條件滿足的記錄結果集.
也就是說返回的結果集中只存在有d.deptno=10的記錄,即emp表中只存在dept表中d.deptno=10的記錄.
SQL> select empno,ename,deptno from scott.emp e where exists(select * from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7782 CLARK 10
7839 KING 10
7934 MILLER 10
in:
第一個where條件必須給定字段(deptno), 第二個sql語句中,必須明確給定要查詢的字段是哪個(deptno).
SQL> select empno,ename,deptno from scott.emp e where deptno in(select deptno from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7782 CLARK 10
7839 KING 10
7934 MILLER 10
Oracle 中exists (in)和not exists(not in)是判斷是否存在和不存在表中記錄的關鍵子.
請注意:not in 邏輯上不完全等同于not exists,如果你誤用了not in,小心你的程序存在致命的BUG:因此,請盡量不要使用not in(它會調用子查詢),而盡量使用not exists(它會調用關聯子查詢)。
本文出自:億恩科技【www.artduck.net】
服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]
|