oracle中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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
實例分析ORACLE數(shù)據(jù)庫性能優(yōu)化
這篇文章主要介紹了從實例著手分析ORACLE數(shù)據(jù)庫性能優(yōu)化問題以及解決辦法,需要的朋友參考下吧。2017-12-12Oracle進行數(shù)據(jù)庫升級和降級的操作代碼
數(shù)據(jù)庫升級是一個復雜的過程,涉及到備份現(xiàn)有數(shù)據(jù)、安裝新版本的數(shù)據(jù)庫軟件、遷移數(shù)據(jù)和應用程序的兼容性測試等步驟,數(shù)據(jù)庫降級通常比升級更具挑戰(zhàn)性,所以本文給大家介紹了Oracle進行數(shù)據(jù)庫升級和降級的操作,需要的朋友可以參考下2024-09-09Oracle中簡單查詢、限定查詢、數(shù)據(jù)排序SQL語句范例和詳細注解
這篇文章主要介紹了Oracle中簡單查詢、限定查詢、數(shù)據(jù)排序SQL語句范例和詳細注解,對查詢語法一并做了介紹,需要的朋友可以參考下2014-07-07關于ORA-04091異常的出現(xiàn)原因分析及解決方案
這篇文章主要介紹了關于ORA-04091異常的出現(xiàn)原因分析及解決方案,本文給大家分享異常出現(xiàn)的場景及解決代碼,感興趣的朋友跟隨小編一起看看吧2023-05-05