<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    憨厚生

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

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      165 隨筆 :: 17 文章 :: 90 評論 :: 0 Trackbacks
    轉:http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html

    in 和 exists也是很好區別的.

    in 是一個集合運算符.

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

    這個運算中,前面是一個元素,后面是一個集合,集合中的元素類型是和前面的元素一樣的.

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

    in 運算用在語句中,它后面帶的select 一定是選一個字段,而不是select *.

    比如說你要判斷某班是否存在一個名為"小明"的學生,你可以用in 運算:

    "小明" in (select sname from student)

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

    同時,你也可以用exists語句:

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

     

    這兩個涵數是差不多的, 但是由于優化方案的不同, 通常NOT EXISTS要比NOT IN 要快, 因為NOT EXISTS可以使用結合算法而NOT IN 就不行了,而EXISTS則不如IN快, 因為這時候IN可能更多的使用結合算法.

     

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

    這句相當于

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


    對于表A的每一條數據,都執行select * from 表B where 表B.id=表A.id的存在性判斷,如果表B中存在表A當前行相同的id,則exists為真,該行顯示,否則不顯示


    exits適合內小外大的查詢,in適合內大外小的查詢

     

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

    EXISTS
    指定一個子查詢,檢測行的存在。

    比較使用 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

    (2 row(s) affected)

     

    exits 相當于存在量詞:表示集合存在,也就是集合不為空只作用一個集合.例如 exist P 表示P不空時為真; not exist P表示p為空時 為真 in表示一個標量和一元關系的關系。例如:s in P表示當s與P中的某個值相等時 為真; s not in P 表示s與P中的每一個值都不相等時 為真

    posted on 2009-03-07 15:56 二胡 閱讀(4898) 評論(3)  編輯  收藏 所屬分類: 數據庫

    評論

    # re: sql中exits和in的區別[未登錄] 2009-04-09 22:09 無名
    很好!  回復  更多評論
      

    # re: sql中exits和in的區別 2010-07-03 14:01 ren
    你寫得很容易理解,謝謝  回復  更多評論
      

    # re: sql中exits和in的區別 2011-03-18 08:16 佛擋殺佛
    @無名
    很好,講的很詳細。可以再補充下exits和in跟索引的關系。  回復  更多評論
      

    主站蜘蛛池模板: 亚洲不卡无码av中文字幕| 日韩精品福利片午夜免费观着| 一本久久综合亚洲鲁鲁五月天 | 日韩精品无码一区二区三区免费 | 亚洲国产精品日韩| 国产精品永久免费视频| ZZIJZZIJ亚洲日本少妇JIZJIZ | a成人毛片免费观看| 久久精品国产亚洲av麻| 99久久成人国产精品免费| 国产V亚洲V天堂无码久久久| 老司机69精品成免费视频| 亚洲黄色免费网站| 毛片a级毛片免费播放100| 亚洲aⅴ天堂av天堂无码麻豆| 国产免费资源高清小视频在线观看 | 日本19禁啪啪无遮挡免费动图| 亚洲AV日韩AV一区二区三曲| 亚洲AV无码不卡在线观看下载| 黄色视屏在线免费播放| 亚洲国产综合专区电影在线| 无码国产精品一区二区免费式直播| 亚洲一卡一卡二新区无人区| 国产伦精品一区二区三区免费迷 | 久久精品国产这里是免费| 亚洲综合一区二区精品久久| 69成人免费视频无码专区| 美美女高清毛片视频黄的一免费| 亚洲另类少妇17p| 日本免费大黄在线观看| 亚洲人AV在线无码影院观看| 久久久久无码专区亚洲av| 99re6在线视频精品免费下载| 亚洲最大的成人网站| 亚洲中文字幕无码爆乳av中文 | 亚洲第一网站免费视频| 免费的涩涩视频在线播放| A毛片毛片看免费| 久久精品国产99国产精品亚洲 | 亚洲国产精品久久久久婷婷软件| 在线观看av永久免费|