數(shù)據(jù)庫中exists語句的用法
數(shù)據(jù)庫中exists語句的用法的用法你知道嗎?下面小編就跟你們詳細(xì)介紹下數(shù)據(jù)庫中exists語句的用法的用法,希望對你們有用。
數(shù)據(jù)庫中exists語句的用法的用法如下:
SQL中EXISTS的用法
問題:查詢學(xué)過編號為"01"并且也學(xué)過編號為"02"的課程的同學(xué)的信息
--方法1
Sql代碼
select Student.* from Student , SC where Student.S# = SC.S# and SC.C# = '01' and exists (Select 1 from SC SC_2 where SC_2.S# = SC.S# and SC_2.C# = '02') order by Student.S#
EXISTS用于檢查子查詢是否至少會返回一行數(shù)據(jù),該子查詢實際上并不返回任何數(shù)據(jù),而是返回值True或False
例表A:TableIn
例表B:TableEx
?。ǘ? 比較使用 EXISTS 和 IN 的查詢。注意兩個查詢返回相同的結(jié)果。
select * from TableIn where exists(select BID from TableEx where BNAME=TableIn.ANAME)
select * from TableIn where ANAME in(select BNAME from TableEx)
?。ㄈ? 比較使用 EXISTS 和 = ANY 的查詢。注意兩個查詢返回相同的結(jié)果。
select * from TableIn where exists(select BID from TableEx where BNAME=TableIn.ANAME)
select * from TableIn where ANAME=ANY(select BNAME from TableEx)
NOT EXISTS 的作用與 EXISTS 正好相反。如果子查詢沒有返回行,則滿足了 NOT EXISTS 中的 WHERE 子句。
一種通俗的可以理解為:將外查詢表的每一行,代入內(nèi)查詢作為檢驗,如果內(nèi)查詢返回的結(jié)果取非空值,則EXISTS子句返回TRUE,這一行行可作為外查詢的結(jié)果行,否則不能作為結(jié)果。
EXISTS與IN的使用效率的問題,通常情況下采用exists要比in效率高,因為IN不走索引,但要看實際情況具體使用:
IN適合于外表大而內(nèi)表小的情況;EXISTS適合于外表小而內(nèi)表大的情況。