程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> sql 中 exist 與 in 的區別

sql 中 exist 與 in 的區別

編輯:關於SqlServer
in 和 exists也是很好區別的. in 是一個集合運算符. a in {a,c,d,s,d....} 這個運算中,前面是一個元素,後面是一個集合,集合中的元素類型是和前面的元素一樣的. 而exists是一個存在判斷,如果後面的查詢中有結果,則exists為真,否則為假. in 運算用在語句中,它後面帶的select 一定是選一個字段,而不是select *. 比如說你要判斷某班是否存在一個名為"小明"的學生,你可以用in 運算: "小明" in (select sname from student) 這樣(select sname from student) 返回的是一個全班姓名的集合,in用於判斷"小明"是否為此集合中的一個數據; 同時,你也可以用exists語句: exists (select * from student where sname="小明") 這兩個涵數是差不多的, 但是由於優化方案的不同, 通常NOT EXISTS要比NOT IN 要快, 因為NOT EXISTS可以使用結合算法而NOT IN 就不行了,而EXISTS則不如IN快, 因為這時候IN可能更多的使用結合算法. select * from 表A where exists(select * from 表B where 表B.id=表A.id) 這句相當於 select * from 表A where id in (select id from 表B)
對於表A的每一條數據,都執行select * from 表B where 表B.id=表A.id的存在性判斷,如果表B中存在表A當前行相同的id,則exists為真,該行顯示,否則不顯示 exits適合內小外大的查詢,in適合內大外小的查詢 IN
確定給定的值是否與子查詢或列表中的值相匹配。 EXISTS
指定一個子查詢,檢測行的存在。 比較使用 EXISTS 和 IN 的查詢 這個例子比較了兩個語義類似的查詢。第一個查詢使用 EXISTS 而第二個查詢使用 IN。注意兩個查詢返回相同的信息。 USE pubs
GO
SELECT DISTINCT pub_name
FROM publishers
WHERE EXISTS
(SELECT *
FROM titles
WHERE pub_id = publishers.pub_id
AND type = 'business')
GO -- Or, using the IN clause: USE pubs
GO
SELECT distinct pub_name
FROM publishers
WHERE pub_id IN
(SELECT pub_id
FROM titles
WHERE type = 'business')
GO 下面是任一查詢的結果集: pub_name
----------------------------------------
Algodata Infosystems
New Moon Books (2 row(s) affected) exits 相當於存在量詞:表示集合存在,也就是集合不為空只作用一個集合.例如 exist P 表示P不空時為真; not exist P表示p為空時 為真 in表示一個標量和一元關系的關系。例如:s in P表示當s與P中的某個值相等時 為真; s not in P 表示s與P中的每一個值都不相等時 為真。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved