oracle中exists和not?exists用法舉例詳解
exists (sql 返回結(jié)果集為真)
not exists (sql 不返回結(jié)果集為真)
exists 與 in 意思相同,語(yǔ)法不同,效率高于in
not exists 與 not in 意思相同,語(yǔ)法不同,效率高于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í)行外查詢(xún)select * from A,然后從外查詢(xún)的數(shù)據(jù)取出一條數(shù)據(jù)傳給內(nèi)查詢(xún)。
2、內(nèi)查詢(xún)執(zhí)行select * from B,外查詢(xún)傳入的數(shù)據(jù)和內(nèi)查詢(xún)獲得的數(shù)據(jù)根據(jù)where后面的條件做匹對(duì),如果存在數(shù)據(jù)滿(mǎn)足A.id=B.id則返回true,如果一條都不滿(mǎn)足則返回false。
3、內(nèi)查詢(xún)返回true,則外查詢(xún)的這行數(shù)據(jù)保留,反之內(nèi)查詢(xún)返回false,則外查詢(xún)的這行數(shù)據(jù)不顯示。外查詢(xún)的所有數(shù)據(jù)逐行查詢(xún)匹對(duì)。
注意:exists或not exists的執(zhí)行順序是先執(zhí)行外查詢(xún)?cè)賵?zhí)行內(nèi)查詢(xún)。這和我們學(xué)的子查詢(xún)概念沖突。
舉例
如下:
表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對(duì)多的關(guān)系 A.ID => B.AID
SELECT ID,NAME FROM A WHERE EXIST (SELECT * FROM B WHERE A.ID=B.AID)
執(zhí)行結(jié)果為
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無(wú)值返回真所以沒(méi)有數(shù)據(jù)
NOT EXISTS 就是反過(guò)來(lái)
SELECT ID,NAME FROM A WHERE NOT EXIST (SELECT * FROM B WHERE A.ID=B.AID)
執(zhí)行結(jié)果為 3 A
===========================================================================
EXISTS = IN,意思相同不過(guò)語(yǔ)法上有點(diǎn)點(diǎn)區(qū)別,好像使用IN效率要差點(diǎn),應(yīng)該是不會(huì)執(zhí)行索引的原因 SELECT ID,NAME FROM A WHERE ID IN (SELECT AID FROM B)
NOT EXISTS = NOT IN ,意思相同不過(guò)語(yǔ)法上有點(diǎn)點(diǎn)區(qū)別 SELECT ID,NAME FROM A WHERE ID NOT IN (SELECT AID FROM B)
下面是普通的用法:
SQL中IN,NOT IN,EXISTS,NOT EXISTS的用法和差別:
IN:確定給定的值是否與子查詢(xún)或列表中的值相匹配。
IN 關(guān)鍵字使您得以選擇與列表中的任意一個(gè)值匹配的行。
當(dāng)要獲得居住在 California、Indiana 或 Maryland 州的所有作者的姓名和州的列表時(shí),就需要下列查詢(xún):
SELECT ProductID, ProductName FROM Northwind.dbo.Products WHERE CategoryID = 1 OR CategoryID= 4 OR CategoryID = 5
然而,如果使用 IN,少鍵入一些字符也可以得到同樣的結(jié)果:
SELECT ProductID, ProductName FROM Northwind.dbo.Products WHERE CategoryID IN (1, 4, 5)
IN 關(guān)鍵字之后的項(xiàng)目必須用逗號(hào)隔開(kāi),并且括在括號(hào)中。
下列查詢(xún)?cè)?titleauthor 表中查找在任一種書(shū)中得到的版稅少于 50% 的所有作者的 au_id,然后從 authors 表中選擇 au_id 與
titleauthor 查詢(xún)結(jié)果匹配的所有作者的姓名:
SELECT au_lname, au_fname FROM authors WHERE au_id IN (SELECT au_id FROM titleauthor WHEREroyaltyper <50)
結(jié)果顯示有一些作者屬于少于 50% 的一類(lèi)。
NOT IN:通過(guò) NOT IN 關(guān)鍵字引入的子查詢(xún)也返回一列零值或更多值。 以下查詢(xún)查找沒(méi)有出版過(guò)商業(yè)書(shū)籍的出版商的名稱(chēng)。
SELECT pub_name FROM publishers WHERE pub_id NOT IN (SELECT pub_id FROM titles WHERE type= 'business')
使用 EXISTS 和 NOT EXISTS 引入的子查詢(xún)可用于兩種集合原理的操作:交集與差集。
兩個(gè)集合的交集包含同時(shí)屬于兩個(gè)原集合的所有元素。
差集包含只屬于兩個(gè)集合中的第一個(gè)集合的元素?! ?/p>
EXISTS:指定一個(gè)子查詢(xún),檢測(cè)行的存在。
本示例所示查詢(xún)查找由位于以字母 B 開(kāi)頭的城市中的任一出版商出版的書(shū)名:
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:后面可以是整句的查詢(xún)語(yǔ)句如:SELECT * FROM titles
IN:后面只能是對(duì)單列:SELECT pub_id FROM titles
NOT EXISTS:
例如,要查找不出版商業(yè)書(shū)籍的出版商的名稱(chēng):
SELECT pub_name FROM publishers WHERE NOT EXISTS (SELECT * FROM titles WHERE pub_id =publishers.pub_id AND type = 'business')
下面的查詢(xún)查找已經(jīng)不銷(xiāo)售的書(shū)的名稱(chēng):
SELECT title FROM titles WHERE NOT EXISTS (SELECT title_id FROM sales WHERE title_id =titles.title_id)
語(yǔ)法
EXISTS subquery參數(shù) subquery:是一個(gè)受限的 SELECT 語(yǔ)句 (不允許有 COMPUTE 子句和 INTO 關(guān)鍵字)。有關(guān)更多信息,請(qǐng)參見(jiàn)SELECT 中有關(guān)子查詢(xún)的討論。
結(jié)果類(lèi)型:Boolean
結(jié)果值:如果子查詢(xún)包含行,則返回 TRUE。
示例
A. 在子查詢(xún)中使用 NULL 仍然返回結(jié)果集這個(gè)例子在子查詢(xún)中指定 NULL,并返回結(jié)果集,通過(guò)使用 EXISTS 仍取值為 TRUE。
USE Northwind GO SELECT CategoryName FROM Categories WHERE EXISTS (SELECT NULL) ORDER BY CategoryName ASC GO
B. 比較使用 EXISTS 和 IN 的查詢(xún)
這個(gè)例子比較了兩個(gè)語(yǔ)義類(lèi)似的查詢(xún)。第一個(gè)查詢(xún)使用 EXISTS 而第二個(gè)查詢(xún)使用 IN。注意兩個(gè)查詢(xún)返回相同的信息。
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
下面是任一查詢(xún)的結(jié)果集:
pub_name
Algodata Infosystems
New Moon Books
C.比較使用 EXISTS 和 = ANY 的查詢(xún)
本示例顯示查找與出版商住在同一城市中的作者的兩種查詢(xún)方法:第一種方法使用 = 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 的查詢(xún)
本示例所示查詢(xún)查找由位于以字母 B 開(kāi)頭的城市中的任一出版商出版的書(shū)名:
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 正相反。如果子查詢(xún)沒(méi)有返回行,則滿(mǎn)足 NOT EXISTS 中的 WHERE 子句。本示例查找不出版商業(yè)書(shū)籍的出版商的名稱(chēng):
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
總結(jié)
到此這篇關(guān)于oracle中exists和not exists用法的文章就介紹到這了,更多相關(guān)oracle exists和not exists用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
計(jì)算機(jī)名稱(chēng)修改后Oracle不能正常啟動(dòng)問(wèn)題分析及解決
更改計(jì)算機(jī)名稱(chēng)后,oracle不能正常啟動(dòng)的相信有很多的朋友都有遇到過(guò)這種情況吧,接下來(lái)為大家介紹下詳細(xì)的解決方法感興趣的朋友可以參考下哈2013-04-04實(shí)例分析ORACLE數(shù)據(jù)庫(kù)性能優(yōu)化
這篇文章主要介紹了從實(shí)例著手分析ORACLE數(shù)據(jù)庫(kù)性能優(yōu)化問(wèn)題以及解決辦法,需要的朋友參考下吧。2017-12-12Oracle進(jìn)行數(shù)據(jù)庫(kù)升級(jí)和降級(jí)的操作代碼
數(shù)據(jù)庫(kù)升級(jí)是一個(gè)復(fù)雜的過(guò)程,涉及到備份現(xiàn)有數(shù)據(jù)、安裝新版本的數(shù)據(jù)庫(kù)軟件、遷移數(shù)據(jù)和應(yīng)用程序的兼容性測(cè)試等步驟,數(shù)據(jù)庫(kù)降級(jí)通常比升級(jí)更具挑戰(zhàn)性,所以本文給大家介紹了Oracle進(jìn)行數(shù)據(jù)庫(kù)升級(jí)和降級(jí)的操作,需要的朋友可以參考下2024-09-09oracle數(shù)據(jù)庫(kù)tns配置方法詳解
TNS是Oracle Net的一部分,專(zhuān)門(mén)用來(lái)管理和配置Oracle數(shù)據(jù)庫(kù)和客戶(hù)端連接的一個(gè)工具,在大多數(shù)情況下客戶(hù)端和數(shù)據(jù)庫(kù)要通訊,必須配置TNS,下面看一如何配置它吧2013-12-12Oracle中簡(jiǎn)單查詢(xún)、限定查詢(xún)、數(shù)據(jù)排序SQL語(yǔ)句范例和詳細(xì)注解
這篇文章主要介紹了Oracle中簡(jiǎn)單查詢(xún)、限定查詢(xún)、數(shù)據(jù)排序SQL語(yǔ)句范例和詳細(xì)注解,對(duì)查詢(xún)語(yǔ)法一并做了介紹,需要的朋友可以參考下2014-07-07快速查出Oracle數(shù)據(jù)庫(kù)中鎖等待的方法
這篇文章主要介紹了快速查出Oracle數(shù)據(jù)庫(kù)中鎖等待的方法,在實(shí)際開(kāi)發(fā)中很有應(yīng)用價(jià)值,需要的朋友可以參考下2014-08-08怎么才能限制SQL Server只能讓指定的機(jī)器連接
怎么才能限制SQL Server只能讓指定的機(jī)器連接...2007-03-03關(guān)于ORA-04091異常的出現(xiàn)原因分析及解決方案
這篇文章主要介紹了關(guān)于ORA-04091異常的出現(xiàn)原因分析及解決方案,本文給大家分享異常出現(xiàn)的場(chǎng)景及解決代碼,感興趣的朋友跟隨小編一起看看吧2023-05-05Oracle 實(shí)現(xiàn)將查詢(xún)結(jié)果保存到文本txt中
這篇文章主要介紹了Oracle 實(shí)現(xiàn)將查詢(xún)結(jié)果保存到文本txt中的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02