1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        Oracle exists and not exist

        發布時間:  2012/9/19 17:30:08

        先看下面的例子: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.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线