主頁 > 知識庫 > 通過分析SQL語句的執(zhí)行計劃優(yōu)化SQL

通過分析SQL語句的執(zhí)行計劃優(yōu)化SQL

熱門標(biāo)簽:數(shù)字匠心電銷機器人 蘭州語音外呼系統(tǒng)運營商 成都電話外呼系統(tǒng)一般多少錢 銀川高頻外呼回?fù)芟到y(tǒng)多少錢 al智能電話機器人 沒聽見電話機器人幫你接 如何做地圖標(biāo)注圖鋪 陜西電銷外呼系統(tǒng)好用嗎 最新人工智能電銷機器人
如何干預(yù)執(zhí)行計劃 - - 使用hints提示

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

hints是oracle提供的一種機制,用來告訴優(yōu)化器按照我們的告訴它的方式生成執(zhí)行計劃。我們可以用hints來實現(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)計數(shù)據(jù),就會使用缺省的統(tǒng)計數(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)鍵字的后面

使用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,并且不會給出任何錯誤。

您可能感興趣的文章:
  • 淺談MySQL中優(yōu)化sql語句查詢常用的30種方法
  • sql語句優(yōu)化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的語句
  • SQL語句優(yōu)化方法30例(推薦)
  • 如何優(yōu)化SQL語句的心得淺談
  • SQL 語句優(yōu)化方法30例
  • 如何優(yōu)化SQL語句(全)
  • 常用SQL語句優(yōu)化技巧總結(jié)【經(jīng)典】
  • SQL語句優(yōu)化提高數(shù)據(jù)庫性能
  • SQL語句性能優(yōu)化(續(xù))
  • sql語句優(yōu)化的一般步驟詳解

標(biāo)簽:鹽城 朔州 通化 宜春 巴彥淖爾 遼源 本溪 邢臺

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《通過分析SQL語句的執(zhí)行計劃優(yōu)化SQL》,本文關(guān)鍵詞  通過,分析,SQL,語句,的,執(zhí)行,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《通過分析SQL語句的執(zhí)行計劃優(yōu)化SQL》相關(guān)的同類信息!
  • 本頁收集關(guān)于通過分析SQL語句的執(zhí)行計劃優(yōu)化SQL的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章