• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    淺談軟件測試開發技術Oracle中的三種Join方法

    發布: 2009-9-11 10:43 | 作者: 不詳 | 來源: 領測軟件測試網 | 查看: 32次 | 進入軟件測試論壇討論

    領測軟件測試網

      通常情況下hash join的效果都比Sort merge join要好,然而如果行源已經被排過序,在執行排序合并連接時不需要再排序了,這時Sort merge join的性能會優于hash join?梢允褂肬SE_MERGE(table_name1 table_name2)來強制使用Sort merge join。

      cost = (outer access cost * # of hash partitions) + inner access cost

      Hash join:

      適用于兩個表的數據量差別很大。但需要注意的是:如果HASH表太大,無法一次構造在內存中,則分成若干個partition,寫入磁盤的temporary segment,則會多一個I/O的代價,會降低效率,此時需要有較大的temporary segment從而盡量提高I/O的性能。

      可以用USE_HASH(table_name1 table_name2)提示來強制使用散列連接。如果使用散列連HASH_AREA_SIZE 初始化參數必須足夠的大,如果是9i,Oracle建議使用SQL工作區自動管理,設置WORKAREA_SIZE_POLICY 為AUTO,然后調整PGA_AGGREGATE_TARGET 即可。

      也可以使用HASH_JOIN_ENABLED=FALSE(默認為TRUE)強制不使用hash join。

      cost = (outer access cost * # of hash partitions) + inner access cost

      效率比較

      Hash join的主要資源消耗在于CPU(在內存中創建臨時的hash表,并進行hash計算),而merge join的資源消耗主要在于磁盤I/O(掃描表或索引)。在并行系統中,hash join對CPU的消耗更加明顯。所以在CPU緊張時,最好限制使用hash join。

      在絕大多數情況下,hash join效率比其他join方式效率更高:

      在Sort-Merge Join(SMJ),兩張表的數據都需要先做排序,然后做merge。因此效率相對最差;

      Nested-Loop Join(NL)效率比SMJ更高。特別是當驅動表的數據量很大(集的勢高)時。這樣可以并行掃描內表。

      Hash join效率最高,因為只要對兩張表掃描一次。

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    22/2<12

    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>