通過(guò)分析SQL語(yǔ)句的執(zhí)行計(jì)劃優(yōu)化SQL
基于代價(jià)的優(yōu)化器是很聰明的,在絕大多數(shù)情況下它會(huì)選擇正確的優(yōu)化器,減輕了DBA的負(fù)擔(dān)。但有時(shí)它也聰明反被聰明誤,選擇了很差的執(zhí)行計(jì)劃,使某個(gè)語(yǔ)句的執(zhí)行變得奇慢無(wú)比。此時(shí)就需要DBA進(jìn)行人為的干預(yù),告訴優(yōu)化器使用我們指定的存取路徑或連接類(lèi)型生成執(zhí)行計(jì)劃,從而使語(yǔ)句高效的運(yùn)行。例如,如果我們認(rèn)為對(duì)于一個(gè)特定的語(yǔ)句,執(zhí)行全表掃描要比執(zhí)行索引掃描更有效,則我們就可以指示優(yōu)化器使用全表掃描。在Oracle中,是通過(guò)為語(yǔ)句添加hints(提示)來(lái)實(shí)現(xiàn)干預(yù)優(yōu)化器優(yōu)化的目的。
hints是oracle提供的一種機(jī)制,用來(lái)告訴優(yōu)化器按照我們的告訴它的方式生成執(zhí)行計(jì)劃。我們可以用hints來(lái)實(shí)現(xiàn):
1. 使用的優(yōu)化器的類(lèi)型
2.基于代價(jià)的優(yōu)化器的優(yōu)化目標(biāo),是all_rows還是first_rows。
3. 表的訪問(wèn)路徑,是全表掃描,還是索引掃描,還是直接利用rowid。
4. 表之間的連接類(lèi)型
5. 表之間的連接順序
6. 語(yǔ)句的并行程度
除了”RULE”提示外,一旦使用的別的提示,語(yǔ)句就會(huì)自動(dòng)的改為使用CBO優(yōu)化器,此時(shí)如果你的數(shù)據(jù)字典中沒(méi)有統(tǒng)計(jì)數(shù)據(jù),就會(huì)使用缺省的統(tǒng)計(jì)數(shù)據(jù)。所以建議大家如果使用CBO或HINTS提示,則最好對(duì)表和索引進(jìn)行定期的分析。
如何使用hints:
Hints只應(yīng)用在它們所在sql語(yǔ)句塊(statement block,由select、update、delete關(guān)鍵字標(biāo)識(shí))上,對(duì)其它SQL語(yǔ)句或語(yǔ)句的其它部分沒(méi)有影響。如:對(duì)于使用union操作的2個(gè)sql語(yǔ)句,如果只在一個(gè)sql語(yǔ)句上有hints,則該hints不會(huì)影響另一個(gè)sql語(yǔ)句。
我們可以使用注釋(comment)來(lái)為一個(gè)語(yǔ)句添加hints,一個(gè)語(yǔ)句塊只能有一個(gè)注釋?zhuān)易⑨屩荒芊旁赟ELECT, UPDATE, or DELETE關(guān)鍵字的后面
使用hints的語(yǔ)法:
{DELETE|INSERT|SELECT|UPDATE} /*+ hint [text] [hint[text]]... */ or {DELETE|INSERT|SELECT|UPDATE} --+ hint [text] [hint[text]]...
注解:
1.DELETE、INSERT、SELECT和UPDATE是標(biāo)識(shí)一個(gè)語(yǔ)句塊開(kāi)始的關(guān)鍵字,包含提示的注釋只能出現(xiàn)在這些關(guān)鍵字的后面,否則提示無(wú)效。
2.“+”號(hào)表示該注釋是一個(gè)hints,該加號(hào)必須立即跟在”/*”的后面,中間不能有空格。
3.hint是下面介紹的具體提示之一,如果包含多個(gè)提示,則每個(gè)提示之間需要用一個(gè)或多個(gè)空格隔開(kāi)。
4.text 是其它說(shuō)明hint的注釋性文本
如果你沒(méi)有正確的指定hints,Oracle將忽略該hints,并且不會(huì)給出任何錯(cuò)誤。
- 淺談MySQL中優(yōu)化sql語(yǔ)句查詢(xún)常用的30種方法
- sql語(yǔ)句優(yōu)化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的語(yǔ)句
- SQL語(yǔ)句優(yōu)化方法30例(推薦)
- 如何優(yōu)化SQL語(yǔ)句的心得淺談
- SQL 語(yǔ)句優(yōu)化方法30例
- 如何優(yōu)化SQL語(yǔ)句(全)
- 常用SQL語(yǔ)句優(yōu)化技巧總結(jié)【經(jīng)典】
- SQL語(yǔ)句優(yōu)化提高數(shù)據(jù)庫(kù)性能
- SQL語(yǔ)句性能優(yōu)化(續(xù))
- sql語(yǔ)句優(yōu)化的一般步驟詳解
相關(guān)文章
SQLServer CONVERT 函數(shù)測(cè)試結(jié)果
SQLServer CONVERT 函數(shù)的一些測(cè)試結(jié)果,大家可以很方便的參考各個(gè)參數(shù)的結(jié)果。2009-07-07淺析SQL Server中的執(zhí)行計(jì)劃緩存(上)
這篇文章主要介紹了淺析SQL Server中的執(zhí)行計(jì)劃緩存(上)的相關(guān)資料,需要的朋友可以參考下2015-12-12記一次公司倉(cāng)庫(kù)數(shù)據(jù)庫(kù)服務(wù)器死鎖過(guò)程及解決辦法
根據(jù)操作系統(tǒng)中的定義:死鎖是指在一組進(jìn)程中的各個(gè)進(jìn)程均占有不會(huì)釋放的資源,但因互相申請(qǐng)被其他進(jìn)程所站用不會(huì)釋放的資源而處于的一種永久等待狀態(tài)。下面小編給大家分享一次公司倉(cāng)庫(kù)數(shù)據(jù)庫(kù)服務(wù)器死鎖過(guò)程及解決辦法,需要的朋友一起看看吧2015-09-09sqlserver 此數(shù)據(jù)庫(kù)沒(méi)有有效所有者錯(cuò)誤的解決方法
此數(shù)據(jù)庫(kù)沒(méi)有有效所有者,因此無(wú)法安裝數(shù)據(jù)庫(kù)關(guān)系圖支持對(duì)象。若要繼續(xù),請(qǐng)首先使用“數(shù)據(jù)庫(kù)屬性”對(duì)話框的“文件”頁(yè)或Alter AUTHORIZATION語(yǔ)句將數(shù)據(jù)庫(kù)所有者設(shè)置為有效登錄名,然后再添加數(shù)據(jù)庫(kù)關(guān)系圖支持對(duì)象。2010-04-04SQL?Server日志清理3種實(shí)現(xiàn)方式
這篇文章主要給大家介紹了關(guān)于SQL?Server日志清理3種實(shí)現(xiàn)方式的相關(guān)資料,在數(shù)據(jù)庫(kù)使用很久后日志文件會(huì)累計(jì)的越來(lái)越大,如果硬盤(pán)空間不足可能會(huì)導(dǎo)致宕機(jī),需要的朋友可以參考下2023-09-09SQL Server復(fù)制刪除發(fā)布時(shí)遇到錯(cuò)誤18752的問(wèn)題及解決方法
朋友反饋他無(wú)法刪除一臺(tái)SQL Server數(shù)據(jù)庫(kù)上的發(fā)布,具體情況為刪除一個(gè)SQL Server Replication的發(fā)布時(shí),遇到這樣的錯(cuò)誤問(wèn)題如何解決呢,下面小編給大家分享SQL Server復(fù)制刪除發(fā)布時(shí)遇到錯(cuò)誤18752的問(wèn)題及解決方法,感興趣的朋友一起看看吧2024-01-01SQLserver2000 企業(yè)版 出現(xiàn)"進(jìn)程51發(fā)生了嚴(yán)重的異常"錯(cuò)誤的處理方法
SQL2000 企業(yè)版 出現(xiàn)“進(jìn)程51發(fā)生了嚴(yán)重的異常”錯(cuò)誤的解決方法,利用了微軟官方的工具。2009-07-07總結(jié)一周內(nèi)學(xué)習(xí)的Sql經(jīng)驗(yàn)(一)
學(xué)習(xí)sql有一周時(shí)間了,這些主要是基礎(chǔ)的內(nèi)容,以后估計(jì)就遇到具體的實(shí)例再拿出來(lái)分析。2014-08-08