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

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

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

    Decode360's Blog

    業(yè)精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 ::  :: 管理 ::
      302 隨筆 :: 26 文章 :: 82 評論 :: 0 Trackbacks
    Oracle的優(yōu)化器的RBO和CBO方式
    ?
    ?
    1、基于規(guī)則的優(yōu)化方式(Rule-Based Optimization,簡稱為RBO)
    ?
    ??? 優(yōu)化器在分析SQL語句時(shí),所遵循的是Oracle內(nèi)部預(yù)定的一些規(guī)則,對數(shù)據(jù)是不敏感的。它只借助少量的信息來決定一個(gè)sql語句的執(zhí)行計(jì)劃,包括:
    ??? 1)sql語句本身
    ??? 2)sql中涉及到的table、view、index等的基本信息
    ??? 3)本地?cái)?shù)據(jù)庫中數(shù)據(jù)字典中的信息(遠(yuǎn)程數(shù)據(jù)庫數(shù)據(jù)字典信息對RBO是無效的)
    ??? 例如:我們常見的,當(dāng)一個(gè)where子句中的一列有索引時(shí)去走索引。但是需要注意,走索引不一定就是優(yōu)的,比如一個(gè)表只有兩行數(shù)據(jù),一次IO就可以完成全表的檢索,而此時(shí)走索引時(shí)則需要兩次IO,這時(shí)全表掃描(full table scan)的效率更優(yōu)。
    ?
    ?
    2、基于代價(jià)的優(yōu)化方式(Cost-Based Optimization,簡稱為CBO)
    ?
    ??? 它是看語句的代價(jià)(Cost),通過代價(jià)引擎來估計(jì)每個(gè)執(zhí)行計(jì)劃所需的代價(jià),該代價(jià)將每個(gè)執(zhí)行計(jì)劃所耗費(fèi)的資源進(jìn)行量化,CBO根據(jù)這個(gè)代價(jià)選擇出最優(yōu)的執(zhí)行計(jì)劃。一個(gè)查詢所耗費(fèi)的資源可分為三部分:I/O代價(jià)、CPU代價(jià)、NETWORK代價(jià)。I/O是指把數(shù)據(jù)從磁盤讀入內(nèi)存時(shí)所需代價(jià)(該代價(jià)是查詢所需最主要的,所以在優(yōu)化時(shí)一個(gè)基本原則就是降低I/O總次數(shù));CPU代價(jià)是指處理內(nèi)存中數(shù)據(jù)所需的代價(jià),數(shù)據(jù)一旦讀入內(nèi)存,當(dāng)我們識別出我們所要的數(shù)據(jù)后,會在這些數(shù)據(jù)上執(zhí)行排序(sort)或連接(join)操作,這需要消耗CPU資源;對于訪問遠(yuǎn)程節(jié)點(diǎn)來說,network代價(jià)的花費(fèi)也是很大的。
    ??? 優(yōu)化器在判斷是否用這種方式時(shí),主要參照的是表及索引的統(tǒng)計(jì)信息。統(tǒng)計(jì)信息給出表的大小、有多少行、每行的長度等信息。這些統(tǒng)計(jì)信息起初在庫內(nèi)是沒有的,是做analyze后才出現(xiàn)的,很多的時(shí)侯過期統(tǒng)計(jì)信息會令優(yōu)化器做出一個(gè)錯(cuò)誤的執(zhí)行計(jì)劃,因些應(yīng)及時(shí)更新這些信息(dbms_stat.analyze)。
    ??? 如星型連接排列查詢,哈希連接查詢,函數(shù)索引,和并行查詢等一些技術(shù)都是基于CBD的。
    ?
    ?
    3、優(yōu)化模式包括Rule、Choose、First rows、All rows四種方式:
    ?
    ??? Rule:基于規(guī)則的方式。
    ??? Choolse:默認(rèn)的情況下Oracle用的便是這種方式。指的是當(dāng)一個(gè)表或或索引有統(tǒng)計(jì)信息,則走CBO的方式,如果表或索引沒統(tǒng)計(jì)信息,表又不是特別的小,而且相應(yīng)的列有索引時(shí),那么就走索引,走RBO的方式。
    ??? First Rows:它與Choose方式是類似的,所不同的是當(dāng)一個(gè)表有統(tǒng)計(jì)信息時(shí),它將是以最快的方式返回查詢的最先的幾行,從總體上減少了響應(yīng)時(shí)間。
    ??? All Rows:也就是我們所說的Cost的方式,當(dāng)一個(gè)表有統(tǒng)計(jì)信息時(shí),它將以最快的方式返回表的所有的行,從總體上提高查詢的吞吐量。沒有統(tǒng)計(jì)信息則走RBO的方式。
    ?
    ?
    4、設(shè)定選用哪種優(yōu)化模式:
    ??? A、在initSID.ora中設(shè)定OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS(默認(rèn)是Choose)
    ??? B、Sessions級別通過:ALTER SESSION SET OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS
    ??? C、語句級別用Hint(/*+ ... */)來設(shè)定
    ?
    ?
    5、一些常見的問題:
    ?
    ? A、為什么表的某個(gè)字段明明有索引,但執(zhí)行計(jì)劃卻不走索引?
    ??? 1、優(yōu)化模式是all_rows的方式
    ??? 2、表作過analyze,有統(tǒng)計(jì)信息
    ??? 3、表很小,上文提到過的,Oracle的優(yōu)化器認(rèn)為不值得走索引。
    ?
    ? B、使用CBO時(shí),SQL語句中為什么不能引用系統(tǒng)數(shù)據(jù)字典表或視圖?
    ??? 1、因?yàn)橄到y(tǒng)數(shù)據(jù)字典表都未被分析過,可能導(dǎo)致極差的“執(zhí)行計(jì)劃”。
    ??? 2、擅自對數(shù)據(jù)字典表做分析,可能導(dǎo)致死鎖,或系統(tǒng)性能嚴(yán)重下降。
    ?
    ? C、使用CBO時(shí)如何選擇表連接方式?
    ??? 1、CBO有時(shí)會偏重于SMJ和HJ,但在OLTP系統(tǒng)中,NL一般會更好,因?yàn)樗咝У氖褂昧怂饕?/font>
    ??? 2、SMJ即使相關(guān)列上建有索引,最多只能因索引的存在,避免數(shù)據(jù)排序過程。
    ??? 3、HJ由于須做HASH運(yùn)算,索引的存在對數(shù)據(jù)查詢速度幾乎沒有影響。
    ?
    ? D、使用CBO時(shí),需要注意什么嗎?
    ??? 1、必須保證為表和相關(guān)的索引搜集足夠的統(tǒng)計(jì)數(shù)據(jù), 對數(shù)據(jù)經(jīng)常有增、刪、改的表最好定期對表和索引進(jìn)行分析
    ??? 2、可用SQL語句:analyze table xxx compute statistics for all indexes
    ?
    ? E、為什么有時(shí)使用CBO會比較慢?
    ??? 1、沒有對表或視圖進(jìn)行Analyze
    ??? 2、SQL進(jìn)行CBO時(shí)對于沒有Analyze的對象會自動進(jìn)行Analyze,因此造成運(yùn)行緩慢
    ?
    ?
    ?
    ?
    其他詳細(xì)信息見收藏夾





    -The End-

    posted on 2008-08-13 14:33 decode360-3 閱讀(7875) 評論(1)  編輯  收藏 所屬分類: Oracle

    評論

    # re: CBO和RBO的區(qū)別 2014-01-27 09:49 鞏華社區(qū)
    SMJ
    HJ
    NL
    都是什么意思?
      回復(fù)  更多評論
      

    主站蜘蛛池模板: 亚洲精品蜜桃久久久久久| 国产精品jizz在线观看免费| 精品国产香蕉伊思人在线在线亚洲一区二区| 亚洲一级毛片免费在线观看| 最近免费最新高清中文字幕韩国| 亚洲精品国产美女久久久| 国产区在线免费观看| 三上悠亚亚洲一区高清| 一个人看的免费高清视频日本| 四虎影视精品永久免费| 美女视频黄a视频全免费网站一区 美女视频黄a视频全免费网站色 | 亚洲午夜久久久久久尤物| 亚洲免费精彩视频在线观看| 亚洲色爱图小说专区| 9久热这里只有精品免费| 国产成人精品日本亚洲专区61| igao激情在线视频免费 | 亚洲av中文无码乱人伦在线r▽| 永久免费A∨片在线观看| 久久精品a亚洲国产v高清不卡| 国产精品久久永久免费| 亚洲精品无码久久久久久| 亚洲国产成人精品无码久久久久久综合 | 最近免费中文字幕大全免费版视频| 亚洲色偷偷av男人的天堂| 91在线视频免费播放| 国产91成人精品亚洲精品| 亚洲一区二区三区香蕉| 97久久免费视频| 亚洲精品无码久久久久久| 国产亚洲精品无码专区| 黄色成人免费网站| 老司机午夜在线视频免费观| 亚洲精品你懂的在线观看| 成人一a毛片免费视频| 国产成人1024精品免费| 亚洲国产综合第一精品小说| 免费在线观看中文字幕| 日本免费一区二区三区四区五六区| 亚洲AV成人噜噜无码网站| 亚洲男人的天堂一区二区|