SQL 中關於EXISTS的用法

來源:互聯網
上載者:User

1.EXISTS 和in 的區別之一就是exists 的執行先執行外面 再執行子查詢;而in的用法就是先執行子查詢然後執行主查詢;

  相關的就是exists 主查詢的表比子查詢的大,in主查詢的比子查詢的範圍小;

2. example

現在又表A  和表B

表A
ID NAME
1    A1

2    A2

3   A3

表B
ID AID NAME
1   
1 B1

2   
2 B2

3   
2 B3

表A和表B是1對多的關係 A.ID => B.AID

SELECT ID,NAME
FROM A
WHERE EXIST (SELECT
* FROM B
WHERE A.ID=B.AID)

執行結果為
1 A1

2 A2

首先 SELECT ID,NAME
FROM A

執行結果為
1    A1

2    A2

3    A3

 

然後把這個結果放在existsde 子查詢中判斷,結果為true 的就保留 ,結果為false的就除掉 顯然

第三條記錄A.ID=3 B.AID=2 他們不相等,結果為false

所以最終的結果為:

1    A1

2
    A2



聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.