国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

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

2024-08-31 00:58:09
字體:
來源:轉載
供稿:網友
如何干預執行計劃 - - 使用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,并且不會給出任何錯誤。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 嘉峪关市| 万山特区| 固始县| 子长县| 巩留县| 丘北县| 汕头市| 泗洪县| 英山县| 永寿县| 安国市| 万荣县| 兴城市| 淮北市| 额尔古纳市| 花莲县| 平罗县| 河南省| 多伦县| 贵港市| 左云县| 上饶县| 静乐县| 吴桥县| 余干县| 凤台县| 东台市| 台北县| 扬中市| 德昌县| 灵山县| 淮南市| 麻阳| 许昌县| 亳州市| 涿州市| 瑞安市| 昌乐县| 炎陵县| 萍乡市| 永定县|