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

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

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

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

    通過分析SQL語句的執行計劃優化SQL(17)

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

    領測軟件測試網 通過分析SQL語句的執行計劃優化SQL(17) SQL語句

    關鍵字:SQL語句 優化SQL 如何干預執行計劃 - - 使用hints提示 

    基于代價的優化器是很聰明的,在絕大多數情況下它會選擇正確的優化器,減輕了DBA的負擔。但有時它也聰明反被聰明誤,選擇了很差的執行計劃,使某個語句的執行變得奇慢無比。此時就需要DBA進行人為的干預,告訴優化器使用我們指定的存取路徑或連接類型生成執行計劃,從而使語句高效的運行。例如,如果我們認為對于一個特定的語句,執行全表掃描要比執行索引掃描更有效,則我們就可以指示優化器使用全表掃描。在ORACLE中,是通過為語句添加hints(提示)來實現干預優化器優化的目的。 


    hints是oracle提供的一種機制,用來告訴優化器按照我們的告訴它的方式生成執行計劃。我們可以用hints來實現: 

    1. 使用的優化器的類型 

    2.基于代價的優化器的優化目標,是all_rows還是first_rows。 

    3. 表的訪問路徑,是全表掃描,還是索引掃描,還是直接利用rowid。 

    4. 表之間的連接類型 

    5. 表之間的連接順序 

    6. 語句的并行程度 


    除了”RULE”提示外,一旦使用的別的提示,語句就會自動的改為使用CBO優化器,此時如果你的數據字典中沒有統計數據,就會使用缺省的統計數據。所以建議大家如果使用CBO或HINTS提示,則最好對表和索引進行定期的分析。 


    如何使用hints: 

    Hints只應用在它們所在sql語句塊(statement block,由select、update、delete關鍵字標識)上,對其它SQL語句或語句的其它部分沒有影響。如:對于使用union操作的2個sql語句,如果只在一個sql語句上有hints,則該hints不會影響另一個sql語句。 


    我們可以使用注釋(comment)來為一個語句添加hints,一個語句塊只能有一個注釋,而且注釋只能放在SELECT, UPDATE, or DELETE關鍵字的后面 


    使用hints的語法: 


    {DELETE|INSERT|SELECT|UPDATE} /*+ hint 
    [text] [hint[text]]... */
    or
    {DELETE|INSERT|SELECT|UPDATE} --+ hint 
    [text] [hint[text]]...
     


    注解: 

    1.DELETE、INSERT、SELECT和UPDATE是標識一個語句塊開始的關鍵字,包含提示的注釋只能出現在這些關鍵字的后面,否則提示無效。 

    2.“+”號表示該注釋是一個hints,該加號必須立即跟在”/*”的后面,中間不能有空格。 

    3.hint是下面介紹的具體提示之一,如果包含多個提示,則每個提示之間需要用一個或多個空格隔開。 

    4.text 是其它說明hint的注釋性文本 


    如果你沒有正確的指定hints,Oracle將忽略該hints,并且不會給出任何錯誤。 
     

    延伸閱讀

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


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(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>