欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle中exists和not?exists用法舉例詳解

 更新時間:2025年01月13日 11:17:49   作者:人生在勤,不索何獲-白大俠  
這篇文章主要介紹了oracle中exists和not?exists用法的相關資料,EXISTS用于檢測子查詢是否返回任何行,而NOT?EXISTS則檢測子查詢是否不返回任何行,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

exists (sql 返回結果集為真)
not exists (sql 不返回結果集為真)
exists 與 in 意思相同,語法不同,效率高于in
not exists 與 not in 意思相同,語法不同,效率高于in

基本概念:

select * from A where not exists(select * from B where A.id = B.id);
select * from A where exists(select * from B where A.id = B.id);

1、首先執(zhí)行外查詢select * from A,然后從外查詢的數(shù)據(jù)取出一條數(shù)據(jù)傳給內(nèi)查詢。

2、內(nèi)查詢執(zhí)行select * from B,外查詢傳入的數(shù)據(jù)和內(nèi)查詢獲得的數(shù)據(jù)根據(jù)where后面的條件做匹對,如果存在數(shù)據(jù)滿足A.id=B.id則返回true,如果一條都不滿足則返回false。

3、內(nèi)查詢返回true,則外查詢的這行數(shù)據(jù)保留,反之內(nèi)查詢返回false,則外查詢的這行數(shù)據(jù)不顯示。外查詢的所有數(shù)據(jù)逐行查詢匹對。

注意:exists或not exists的執(zhí)行順序是先執(zhí)行外查詢再執(zhí)行內(nèi)查詢。這和我們學的子查詢概念沖突。

舉例

如下:

表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) 

執(zhí)行結果為

1 A1
2 A2

原因可以按照如下分析

SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=1) 
--->SELECT * FROM B WHERE B.AID=1有值返回真所以有數(shù)據(jù) 

SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=2) 
--->SELECT * FROM B WHERE B.AID=2有值返回真所以有數(shù)據(jù) 

SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=3) 
--->SELECT * FROM B WHERE B.AID=3無值返回真所以沒有數(shù)據(jù)

NOT EXISTS 就是反過來

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

執(zhí)行結果為 3 A

===========================================================================

EXISTS = IN,意思相同不過語法上有點點區(qū)別,好像使用IN效率要差點,應該是不會執(zhí)行索引的原因 
SELECT ID,NAME FROM A  WHERE ID IN (SELECT AID FROM B) 
NOT EXISTS = NOT IN ,意思相同不過語法上有點點區(qū)別 
SELECT ID,NAME FROM A WHERE ID NOT IN (SELECT AID FROM B) 

下面是普通的用法:

SQL中IN,NOT IN,EXISTS,NOT EXISTS的用法和差別:

IN:確定給定的值是否與子查詢或列表中的值相匹配。  

IN 關鍵字使您得以選擇與列表中的任意一個值匹配的行。

  當要獲得居住在 California、Indiana 或 Maryland 州的所有作者的姓名和州的列表時,就需要下列查詢:

SELECT ProductID, ProductName FROM Northwind.dbo.Products WHERE CategoryID = 1 OR CategoryID= 4 OR CategoryID = 5 

然而,如果使用 IN,少鍵入一些字符也可以得到同樣的結果:

SELECT ProductID, ProductName FROM Northwind.dbo.Products WHERE CategoryID IN (1, 4, 5) 

IN 關鍵字之后的項目必須用逗號隔開,并且括在括號中。

  下列查詢在 titleauthor 表中查找在任一種書中得到的版稅少于 50% 的所有作者的 au_id,然后從 authors 表中選擇 au_id 與

  titleauthor 查詢結果匹配的所有作者的姓名:

SELECT au_lname, au_fname FROM authors WHERE au_id IN (SELECT au_id FROM titleauthor WHEREroyaltyper <50) 

結果顯示有一些作者屬于少于 50% 的一類。

  NOT IN:通過 NOT IN 關鍵字引入的子查詢也返回一列零值或更多值。  以下查詢查找沒有出版過商業(yè)書籍的出版商的名稱。

  SELECT pub_name FROM publishers WHERE pub_id NOT IN (SELECT pub_id FROM titles WHERE type= 'business')  

  使用 EXISTS 和 NOT EXISTS 引入的子查詢可用于兩種集合原理的操作:交集與差集。

  兩個集合的交集包含同時屬于兩個原集合的所有元素。

  差集包含只屬于兩個集合中的第一個集合的元素?! ?/p>

  EXISTS:指定一個子查詢,檢測行的存在。  

  本示例所示查詢查找由位于以字母 B 開頭的城市中的任一出版商出版的書名:

SELECT DISTINCT pub_name FROM publishers WHERE EXISTS (SELECT * FROM titles WHERE pub_id= publishers.pub_id AND type = 'business') 
SELECT distinct pub_name FROM publishers WHERE pub_id IN (SELECT pub_id FROM titles WHEREtype = 'business') 

兩者的區(qū)別:

  EXISTS:后面可以是整句的查詢語句如:SELECT * FROM titles

  IN:后面只能是對單列:SELECT pub_id FROM titles

  NOT EXISTS:

  例如,要查找不出版商業(yè)書籍的出版商的名稱:

SELECT pub_name FROM publishers WHERE NOT EXISTS (SELECT * FROM titles WHERE pub_id =publishers.pub_id AND type = 'business') 

下面的查詢查找已經(jīng)不銷售的書的名稱:

SELECT title FROM titles WHERE NOT EXISTS (SELECT title_id FROM sales WHERE title_id =titles.title_id) 

語法

EXISTS subquery參數(shù) subquery:是一個受限的 SELECT 語句 (不允許有 COMPUTE 子句和 INTO 關鍵字)。有關更多信息,請參見SELECT 中有關子查詢的討論。

結果類型:Boolean

結果值:如果子查詢包含行,則返回 TRUE。

示例

A. 在子查詢中使用 NULL 仍然返回結果集這個例子在子查詢中指定 NULL,并返回結果集,通過使用 EXISTS 仍取值為 TRUE。

USE Northwind 
GO 
SELECT CategoryName 
FROM Categories 
WHERE EXISTS (SELECT NULL) 
ORDER BY CategoryName ASC 
GO 

B. 比較使用 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

C.比較使用 EXISTS 和 = ANY 的查詢

本示例顯示查找與出版商住在同一城市中的作者的兩種查詢方法:第一種方法使用 = ANY,第二種方法使用EXISTS。注意這兩種方法返回相同的信息。

USE pubs 
GO 
SELECT au_lname, au_fname 
FROM authors 
WHERE exists 
    (SELECT * 
    FROM publishers 
    WHERE authors.city = publishers.city) 
GO 

-- Or, using = ANY 

USE pubs 
GO 
SELECT au_lname, au_fname 
FROM authors 
WHERE city = ANY 
    (SELECT city 
    FROM publishers) 
GO 

D.比較使用 EXISTS 和 IN 的查詢

本示例所示查詢查找由位于以字母 B 開頭的城市中的任一出版商出版的書名:

USE pubs 
GO 
SELECT title 
FROM titles 
WHERE EXISTS 
    (SELECT * 
    FROM publishers 
    WHERE pub_id = titles.pub_id 
    AND city LIKE \'B%\') 
GO 

-- Or, using IN: 

USE pubs 
GO 
SELECT title 
FROM titles 
WHERE pub_id IN 
    (SELECT pub_id 
    FROM publishers 
    WHERE city LIKE \'B%\') 
GO 

E. 使用 NOT EXISTS

NOT EXISTS 的作用與 EXISTS 正相反。如果子查詢沒有返回行,則滿足 NOT EXISTS 中的 WHERE 子句。本示例查找不出版商業(yè)書籍的出版商的名稱:

USE pubs 
GO 
SELECT pub_name 
FROM publishers 
WHERE NOT EXISTS 
    (SELECT * 
    FROM titles 
    WHERE pub_id = publishers.pub_id 
    AND type = \'business\') 
ORDER BY pub_name 
GO 

總結 

到此這篇關于oracle中exists和not exists用法的文章就介紹到這了,更多相關oracle exists和not exists用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論