oracle exists and not exist

ForTechnology發表於2011-12-01
oracle exists and not exist
ORACLE 2007-08-30 11:06:08 閱讀6221 評論1   字號:大中小 訂閱
先看下面的例子: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(它會呼叫關聯子查詢)。

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25897606/viewspace-712510/,如需轉載,請註明出處,否則將追究法律責任。

相關文章