自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

五分鐘精通Oracle Hints

數(shù)據(jù)庫(kù) Oracle
這里介紹Oracle Hints是一種機(jī)制,用來(lái)告訴優(yōu)化器按照我們的告訴它的方式生成執(zhí)行計(jì)劃,建議大家如果使用CBO或Hints提示,則最好對(duì)表和索引進(jìn)行定期的分析。

在向大家詳細(xì)介紹Oracle Hints之前,首先讓大家了解下Oracle Hints是什么,然后全面介紹Oracle Hints,希望對(duì)大家有用?;诖鷥r(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)化器使用我們指定的存取路徑或連接類型生成執(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)化的目的。

Oracle Hints是一種機(jī)制,用來(lái)告訴優(yōu)化器按照我們的告訴它的方式生成執(zhí)行計(jì)劃。我們可以用Oracle Hints來(lái)實(shí)現(xiàn):
1) 使用的優(yōu)化器的類型
2) 基于代價(jià)的優(yōu)化器的優(yōu)化目標(biāo),是all_rows還是first_rows。
3) 表的訪問(wèn)路徑,是全表掃描,還是索引掃描,還是直接利用rowid。
4) 表之間的連接類型
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è)注釋,而且注釋只能放在SELECT, UPDATE, or DELETE關(guān)鍵字的后面

使用Oracle 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ò)誤。

【編輯推薦】

  1. 討論Oracle文檔學(xué)習(xí)經(jīng)驗(yàn)
  2. 如何了解Oracle生成執(zhí)行計(jì)劃
  3. 詳細(xì)談?wù)揙racle表連接
  4. 分析Oracle索引掃描四大類
  5. 高手閑談Oracle索引掃描
責(zé)任編輯:佚名 來(lái)源: 博客
相關(guān)推薦

2009-10-22 16:18:19

Oracle表空間

2009-11-17 14:50:50

Oracle調(diào)優(yōu)

2009-10-30 13:12:40

VB.NET創(chuàng)建類

2009-11-20 18:08:37

Oracle數(shù)據(jù)庫(kù)

2009-11-02 18:07:58

Oracle數(shù)據(jù)庫(kù)

2024-12-11 07:00:00

面向?qū)ο?/a>代碼

2025-03-13 06:22:59

2020-06-16 08:47:53

磁盤

2009-11-20 17:06:49

Oracle數(shù)據(jù)庫(kù)字符

2024-07-12 10:00:00

time模塊Python

2009-11-05 14:53:54

Visual Stud

2021-10-19 07:27:08

HTTP代理網(wǎng)絡(luò)

2025-01-20 08:50:00

2024-09-18 08:21:24

JavaScriptTypeScriptprototype

2019-08-09 10:33:36

開(kāi)發(fā)技能代碼

2021-06-07 09:51:22

原型模式序列化

2023-09-07 23:52:50

Flink代碼

2009-11-16 09:53:56

PHP上傳類

2023-07-23 18:47:59

Docker開(kāi)源

2021-12-01 06:50:50

Docker底層原理
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)