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

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

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

    斷點

    每天進步一點點!
    posts - 174, comments - 56, trackbacks - 0, articles - 21

    oracle中的 exists 和 in 的效率問題

    Posted on 2010-01-14 21:42 斷點 閱讀(296) 評論(0)  編輯  收藏 所屬分類: Oracle

    有兩個簡單例子,以說明 “exists”和“in”的效率問題

    1) select * from T1 where exists(select * from T2 where T1.a=T2.a) ;

        T1數據量小而T2數據量非常大時,T1<<T2 時,1) 的查詢效率高。

    2) select * from T1 where T1.a in (select T2.a from T2) ;

         T1數據量非常大而T2數據量小時,T1>>T2 時,2) 的查詢效率高。

    exists 用法:

    1)句中的“select * from T2 where T1.a=T2.a” 相當于一個關聯表查詢,

         相當于“select * from T1,T2  where T1.a=T2.a”;

        “exists(xxx)”它只在乎括號里的數據能不能查找出來,是否存在這樣的記錄,如果存在,這1)句的where 條件成立。

    in的用法:

    2)句中的“select * from T1 where T1.a in (select T2.a from T2) ”,這里的“in”后面括號里的語句搜索出來的字段的內容一定要相對應,一般來說,T1和T2這兩個表的a字段表達的意義應該是一樣的,否則這樣查沒什么意義。

    ---------------------------------------------------------------

    +++++++++++++   下面轉載  +++++++++++++++++++

    ---------------------------------------------------------------

    今天市場報告有個sql及慢,運行需要20多分鐘,如下:
    update p_container_decl cd
    set cd.ANNUL_FLAG=\'0001\',ANNUL_DATE = sysdate
    where exists(
    select 1
    from (
    select tc.decl_no,tc.goods_no
    from p_transfer_cont tc,P_AFFIRM_DO ad
    where tc.GOODS_DECL_NO = ad.DECL_NO
    and ad.DECL_NO = \'sssssssssssssssss\'
    ) a
    where a.decl_no = cd.decl_no
    and a.goods_no = cd.goods_no
    )
    上面涉及的3個表的記錄數都不小,均在百萬左右。根據這種情況,我想到了前不久看的tom的一篇文章,說的是exists和in的區別,in 是把外表和那表作hash join,而exists是對外表作loop,每次loop再對那表進行查詢。
    這樣的話,in適合內外表都很大的情況,exists適合外表結果集很小的情況。

    而我目前的情況適合用in來作查詢,于是我改寫了sql,如下:
    update p_container_decl cd
    set cd.ANNUL_FLAG=\'0001\',ANNUL_DATE = sysdate
    where (decl_no,goods_no) in
    (
    select tc.decl_no,tc.goods_no
    from p_transfer_cont tc,P_AFFIRM_DO ad
    where tc.GOODS_DECL_NO = ad.DECL_NO
    and ad.DECL_NO = ‘ssssssssssss’
    )

    讓市場人員測試,結果運行時間在1分鐘內。問題解決了,看來exists和in確實是要根據表的數據量來決定使用。

    --------------------------------------------------------------------------


    posted @ 2009-02-01 17:54 斷點 閱讀(240) | 評論 (0)
    主站蜘蛛池模板: 免费手机在线看片| 亚洲精品美女久久久久久久| 全部在线播放免费毛片| 成人永久免费福利视频网站| 亚洲aⅴ天堂av天堂无码麻豆| 成人无码区免费视频观看| 亚洲国产综合精品中文第一| 丁香花在线观看免费观看| 亚洲一区二区三区丝袜| 国产一级高清视频免费看| 免费又黄又爽又猛大片午夜| 精品国产香蕉伊思人在线在线亚洲一区二区 | 免费在线观看一级毛片| 成年网站免费入口在线观看| 亚洲日韩精品无码专区网站| 中文字幕无码毛片免费看| 日韩亚洲Av人人夜夜澡人人爽| 亚洲免费视频观看| 亚洲熟妇av午夜无码不卡| 免费一级毛片一级毛片aa| 人人爽人人爽人人片A免费| 国产亚洲精久久久久久无码| 99久热只有精品视频免费看 | 国产男女猛烈无遮挡免费视频网站| 国产综合激情在线亚洲第一页| 国产亚洲日韩一区二区三区| 91成人在线免费视频| 亚洲色成人网站WWW永久四虎| www.亚洲色图| 99国产精品免费观看视频| 亚洲爆乳大丰满无码专区| 久久久久亚洲精品无码网址| 67194成手机免费观看| 亚洲av无码成人影院一区| 亚洲国产另类久久久精品黑人| 7723日本高清完整版免费| 自拍偷自拍亚洲精品播放| 亚洲Av无码精品色午夜| 啦啦啦手机完整免费高清观看| 一级一看免费完整版毛片| 亚洲天堂一区二区三区四区|