憨厚生

          ----Java's Slave----
          ***Java's Host***

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            165 隨筆 :: 17 文章 :: 90 評(píng)論 :: 0 Trackbacks
          轉(zhuǎn):http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html

          in 和 exists也是很好區(qū)別的.

          in 是一個(gè)集合運(yùn)算符.

          a in {a,c,d,s,d....}

          這個(gè)運(yùn)算中,前面是一個(gè)元素,后面是一個(gè)集合,集合中的元素類(lèi)型是和前面的元素一樣的.

          而exists是一個(gè)存在判斷,如果后面的查詢中有結(jié)果,則exists為真,否則為假.

          in 運(yùn)算用在語(yǔ)句中,它后面帶的select 一定是選一個(gè)字段,而不是select *.

          比如說(shuō)你要判斷某班是否存在一個(gè)名為"小明"的學(xué)生,你可以用in 運(yùn)算:

          "小明" in (select sname from student)

          這樣(select sname from student) 返回的是一個(gè)全班姓名的集合,in用于判斷"小明"是否為此集合中的一個(gè)數(shù)據(jù);

          同時(shí),你也可以用exists語(yǔ)句:

          exists (select * from student where sname="小明")

           

          這兩個(gè)涵數(shù)是差不多的, 但是由于優(yōu)化方案的不同, 通常NOT EXISTS要比NOT IN 要快, 因?yàn)镹OT EXISTS可以使用結(jié)合算法而NOT IN 就不行了,而EXISTS則不如IN快, 因?yàn)檫@時(shí)候IN可能更多的使用結(jié)合算法.

           

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

          這句相當(dāng)于

          select * from 表A where id in (select id from 表B)


          對(duì)于表A的每一條數(shù)據(jù),都執(zhí)行select * from 表B where 表B.id=表A.id的存在性判斷,如果表B中存在表A當(dāng)前行相同的id,則exists為真,該行顯示,否則不顯示


          exits適合內(nèi)小外大的查詢,in適合內(nèi)大外小的查詢

           

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

          EXISTS
          指定一個(gè)子查詢,檢測(cè)行的存在。

          比較使用 EXISTS 和 IN 的查詢

          這個(gè)例子比較了兩個(gè)語(yǔ)義類(lèi)似的查詢。第一個(gè)查詢使用 EXISTS 而第二個(gè)查詢使用 IN。注意兩個(gè)查詢返回相同的信息。

          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

          下面是任一查詢的結(jié)果集:

          pub_name
          ----------------------------------------
          Algodata Infosystems
          New Moon Books

          (2 row(s) affected)

           

          exits 相當(dāng)于存在量詞:表示集合存在,也就是集合不為空只作用一個(gè)集合.例如 exist P 表示P不空時(shí)為真; not exist P表示p為空時(shí) 為真 in表示一個(gè)標(biāo)量和一元關(guān)系的關(guān)系。例如:s in P表示當(dāng)s與P中的某個(gè)值相等時(shí) 為真; s not in P 表示s與P中的每一個(gè)值都不相等時(shí) 為真

          posted on 2009-03-07 15:56 二胡 閱讀(4895) 評(píng)論(3)  編輯  收藏 所屬分類(lèi): 數(shù)據(jù)庫(kù)

          評(píng)論

          # re: sql中exits和in的區(qū)別[未登錄](méi) 2009-04-09 22:09 無(wú)名
          很好!  回復(fù)  更多評(píng)論
            

          # re: sql中exits和in的區(qū)別 2010-07-03 14:01 ren
          你寫(xiě)得很容易理解,謝謝  回復(fù)  更多評(píng)論
            

          # re: sql中exits和in的區(qū)別 2011-03-18 08:16 佛擋殺佛
          @無(wú)名
          很好,講的很詳細(xì)。可以再補(bǔ)充下exits和in跟索引的關(guān)系。  回復(fù)  更多評(píng)論
            

          主站蜘蛛池模板: 荣昌县| 贵定县| 新巴尔虎右旗| 二手房| 息烽县| 温州市| 钦州市| 蓬安县| 昌都县| 霍城县| 新晃| 宕昌县| 广汉市| 蕲春县| 浮梁县| 祁门县| 阿巴嘎旗| 泽普县| 南漳县| 乌拉特前旗| 阿勒泰市| 岚皋县| 禹州市| 壶关县| 清镇市| 容城县| 雅江县| 和平区| 钟祥市| 马尔康县| 定州市| 英山县| 云龙县| 托克托县| 滕州市| 沈丘县| 赞皇县| 桦南县| 双鸭山市| 天长市| 南宫市|