新聞中心
在向大家詳細(xì)介紹Oracle Hints之前,首先讓大家了解下Oracle Hints是什么,然后全面介紹Oracle Hints,希望對大家有用。基于代價的優(yōu)化器是很聰明的,在絕大多數(shù)情況下它會選擇正確的優(yōu)化器,減輕了DBA的負(fù)擔(dān)。但有時它也聰明反被聰明誤,選擇了很差的執(zhí)行計(jì)劃,使某個語句的執(zhí)行變得奇慢無比。

成都創(chuàng)新互聯(lián)公司不只是一家網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司;我們對營銷、技術(shù)、服務(wù)都有自己獨(dú)特見解,公司采取“創(chuàng)意+綜合+營銷”一體化的方式為您提供更專業(yè)的服務(wù)!我們經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。我們珍視每一份信任,關(guān)注我們的網(wǎng)站建設(shè)、成都網(wǎng)站制作質(zhì)量和服務(wù)品質(zhì),在得到用戶滿意的同時,也能得到同行業(yè)的專業(yè)認(rèn)可,能夠?yàn)樾袠I(yè)創(chuàng)新發(fā)展助力。未來將繼續(xù)專注于技術(shù)創(chuàng)新,服務(wù)升級,滿足企業(yè)一站式成都全網(wǎng)營銷需求,讓再小的成都品牌網(wǎng)站建設(shè)也能產(chǎn)生價值!
此時就需要DBA進(jìn)行人為的干預(yù),告訴優(yōu)化器使用我們指定的存取路徑或連接類型生成執(zhí)行計(jì)劃,從而使語句高效的運(yùn)行。例如,如果我們認(rèn)為對于一個特定的語句,執(zhí)行全表掃描要比執(zhí)行索引掃描更有效,則我們就可以指示優(yōu)化器使用全表掃描。在Oracle中,是通過為語句添加 Hints(提示)來實(shí)現(xiàn)干預(yù)優(yōu)化器優(yōu)化的目的。
Oracle Hints是一種機(jī)制,用來告訴優(yōu)化器按照我們的告訴它的方式生成執(zhí)行計(jì)劃。我們可以用Oracle Hints來實(shí)現(xiàn):
1) 使用的優(yōu)化器的類型
2) 基于代價的優(yōu)化器的優(yōu)化目標(biāo),是all_rows還是first_rows。
3) 表的訪問路徑,是全表掃描,還是索引掃描,還是直接利用rowid。
4) 表之間的連接類型
5) 表之間的連接順序
6) 語句的并行程度
除了”RULE”提示外,一旦使用的別的提示,語句就會自動的改為使用CBO優(yōu)化器,此時如果你的數(shù)據(jù)字典中沒有統(tǒng)計(jì)數(shù)據(jù),就會使用缺省的統(tǒng)計(jì)數(shù)據(jù)。所以建議大家如果使用CBO或Hints提示,則***對表和索引進(jìn)行定期的分析。
如何使用Hints:
Hints只應(yīng)用在它們所在sql語句塊(statement block,由select、update、delete關(guān)鍵字標(biāo)識)上,對其它SQL語句或語句的其它部分沒有影響。如:對于使用union操作的2個 sql語句,如果只在一個sql語句上有Hints,則該Hints不會影響另一個sql語句。
我們可以使用注釋(comment)來為一個語句添加Hints,一個語句塊只能有一個注釋,而且注釋只能放在SELECT, UPDATE, or DELETE關(guān)鍵字的后面
使用Oracle Hints的語法:
{DELETE|INSERT|SELECT|UPDATE} /*+ hint [text] [hint[text]]... */
or
{DELETE|INSERT|SELECT|UPDATE} --+ hint [text] [hint[text]]...
注解:
1) DELETE、INSERT、SELECT和UPDATE是標(biāo)識一個語句塊開始的關(guān)鍵字,包含提示的注釋只能出現(xiàn)在這些關(guān)鍵字的后面,否則提示無效。
2) “+”號表示該注釋是一個Hints,該加號必須立即跟在”/*”的后面,中間不能有空格。
3) hint是下面介紹的具體提示之一,如果包含多個提示,則每個提示之間需要用一個或多個空格隔開。
4) text 是其它說明hint的注釋性文本
如果你沒有正確的指定Hints,Oracle將忽略該Hints,并且不會給出任何錯誤。
分享文章:五分鐘精通OracleHints
文章轉(zhuǎn)載:http://fisionsoft.com.cn/article/dhspdde.html


咨詢
建站咨詢
