日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

SQL中EXISTS的用法

系統(tǒng) 2210 0

?

問題:查詢學(xué)過編號(hào)為"01"并且也學(xué)過編號(hào)為"02"的課程的同學(xué)的信息

--方法1

      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用于檢查子查詢是否至少會(huì)返回一行數(shù)據(jù),該子查詢實(shí)際上并不返回任何數(shù)據(jù),而是返回值True或False

?

例表A:TableIn 例表B:TableEx
SQL中EXISTS的用法

SQL中EXISTS的用法

?

(二). 比較使用 EXISTS 和 IN 的查詢。注意兩個(gè)查詢返回相同的結(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 的查詢。注意兩個(gè)查詢返回相同的結(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)查詢作為檢驗(yàn),如果內(nèi)查詢返回的結(jié)果取非空值,則EXISTS子句返回TRUE,這一行行可作為外查詢的結(jié)果行,否則不能作為結(jié)果。

?

EXISTS與IN的使用效率的問題, 通常情況下采用exists要比in效率高,因?yàn)镮N不走索引 ,但要看實(shí)際情況具體使用:

IN適合于外表大而內(nèi)表小的情況;EXISTS適合于外表小而內(nèi)表大的情況

?

SQL中EXISTS的用法


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 游戏| 富宁县| 利川市| 汉寿县| 曲周县| 林西县| 耿马| 乡城县| 长丰县| 南郑县| 金山区| 当雄县| 通化县| 梧州市| 江城| 丰都县| 民权县| 津南区| 新民市| 盖州市| 平湖市| 梨树县| 河曲县| 巨鹿县| 洞头县| 额尔古纳市| 霸州市| 河北区| 乌鲁木齐市| 邹平县| 常州市| 哈尔滨市| 嘉荫县| 平谷区| 贡觉县| 安福县| 霍城县| 长寿区| 延庆县| 蒲江县| 鄂尔多斯市|