亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

說一說Oracle的優化器(Optimizer)

2024-08-29 13:49:11
字體:
來源:轉載
供稿:網友

  
本文的目的:
1、說一說Oracle的Optimizer及其相關的一些知識。
2、回答一下為什么有時一個表的某個字段明明有索引,當觀察一些SQL的執行計劃時,發現確不走索引的問題。
3、假如你對 FIRST_ROWS、 ALL_ROWS這兩種模式有迷惑時也可以看一下這篇文章。

開始吧:


Oracle在執行一個SQL之前,首先要分析一下語句的執行計劃,然后再按執行計劃去執行。分析語句的執行計劃的工作是由優化器(Optimizer)來完成的。不同的情況,一條SQL可能有多種執行計劃,但在某一時點,一定只有一種執行計劃是最優的,花費時間是最少的。相信你一定會用Pl/sql Developer、Toad等工具去看一個語句的執行計劃,不過你可能對Rule、Choose、First rows、All rows這幾項有疑問,因為我當初也是這樣的,那時我也迷惑為什么選了以上的不同的項,執行計劃就變了?

1、優化器的優化方式

Oracle的優化器共有兩種的優化方式,即基于規則的優化方式(Rule-Based Optimization,簡稱為RBO)和基于代價的優化方式(Cost-Based Optimization,簡稱為CBO)。
A、RBO方式:優化器在分析SQL語句時,所遵循的是Oracle內部預定的一些規則。比如我們常見的,當一個where子句中的一列有索引時去走索引。
B、CBO方式:依詞義可知,它是看語句的代價(Cost)了,這里的代價主要指Cpu和內存。優化器在判定是否用這種方式時,主要參照的是表及索引的統計信息。統計信息給出表的大小 、有少行、每行的長度等信息。這些統計信息起初在庫內是沒有的,是你在做analyze后才出現的,很多的時侯過期統計信息會令優化器做出一個錯誤的執行計劃,因些我們應及時更新這些信息。在Oracle8及以后的版本,Oracle列推薦用CBO的方式。

我們要明了,不一定走索引就是優的,比如一個表只有兩行數據,一次IO就可以完成全表的檢索,而此時走索引時則需要兩次IO,這時對這個表做全表掃描(full table scan)是最好的。

2、優化器的優化模式(Optermizer Mode)

優化模式包括Rule,Choose,First rows,All rows這四種方式,也就是我們以上所提及的。如下我解釋一下:

Rule:不用多說,即走基于規則的方式。

Choolse:這是我們應觀注的,默認的情況下Oracle用的便是這種方式。指的是當一個表或或索引有統計信息,則走CBO的方式,假如表或索引沒統計信息,表又不是非凡的小,而且相應的列有索引時,那么就走索引,走RBO的方式。

First Rows:它與Choose方式是類似的,所不同的是當一個表有統計信息時,它將是以最快的方式返回查詢的最先的幾行,從總體上減少了響應時間。

All Rows:也就是我們所說的Cost的方式,當一個表有統計信息時,它將以最快的方式返回表的所有的行,從總體上提高查詢的吞吐量。沒有統計信息則走基于規則的方式。

3、如何設定選用哪種優化模式

a、Instance級別

我們可以通過在init<SID>.ora文件中設定OPTIMIZER_MODE=RULE、OPTIMIZER_MODE=CHOOSE、OPTIMIZER_MODE=FIRST_ROWS、OPTIMIZER_MODE=ALL_ROWS去選用3所提的四種方式,假如你沒設定OPTIMIZER_MODE參數則默認用的是Choose這種方式。

B、sessions級別

通過SQL> ALTER SESSION SET OPTIMIZER_MODE=<Mode>;來設定。
 
C、語句級別

這些需要用到Hint,比如:
SQL> SELECT /*+ RULE */ a.userid,
 2     b.name,
 3     b.depart_name
 4      FROM tf_f_yhda a,
 5                tf_f_depart b
 6     WHERE a.userid=b.userid;

4、為什么有時一個表的某個字段明明有索引,當觀察一些語的執行計劃確不走索引呢?如何解決呢?

A、不走索引大體有以下幾個原因
 ♀你在Instance級別所用的是all_rows的方式
 ♀你的表的統計信息(最可能的原因)
 ♀你的表很小,上文提到過的,Oracle的優化器認為不值得走索引。
B、解決方法
 ♀可以修改init<SID>.ora中的OPTIMIZER_MODE這個參數,把它改為Rule或Choose,重起數據庫。也可以使用4中所提的Hint.
 ♀刪除統計信息
   SQL>analyze table table_name delete statistics;
 ♀表小不走索引是對的,不用調的。

5、其它相關

A、如何看一個表或索引是否是統計信息

 SQL>SELECT * FROM user_tables
  2   WHERE table_name=<table_name>
  3 AND num_rows is not null;

 SQL>SELECT * FROM user_indexes
  2   WHERE table_name=<table_name>
  3     AND num_rows is not null;

b、假如我們先用CBO的方式,我們應及時去更新表和索引的統計信息,以免生形不切合實的執行計劃。

 
 SQL> ANALYZE TABLE table_name COMPUTE STATISTICS;
 SQL> ANALYZE INDEX index_name ESTIMATE STATISTICS;

具體的ANALYZE語句請參照Oracle8i/9i 的refrence文檔。

(全文完)

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91亚洲国产成人久久精品网站| 97在线免费视频| 亚洲一区第一页| 一本色道久久综合狠狠躁篇怎么玩| 亚洲一区国产精品| 成人亲热视频网站| 亚洲精品欧美极品| 97在线日本国产| 欧美精品九九久久| 欧美极品美女电影一区| 欧美日韩亚洲国产一区| 一区二区三区四区视频| 国产精品久久久久久久9999| 国产精品一区二区av影院萌芽| 亚洲高清一二三区| 成人免费网站在线观看| 亚洲女人天堂色在线7777| 国产在线观看91精品一区| 精品亚洲aⅴ在线观看| 亚洲欧美成人网| 国产精品嫩草影院久久久| 国产91成人video| 日韩精品高清在线| 色综合伊人色综合网| 成人黄色av免费在线观看| 精品久久中文字幕久久av| 黑人巨大精品欧美一区二区免费| 亚洲香蕉伊综合在人在线视看| 国产精品av免费在线观看| 福利一区视频在线观看| 亚洲欧美日韩久久久久久| 亚洲一区二区三区毛片| 神马久久桃色视频| 影音先锋欧美在线资源| 久久久国产精品x99av| 国产精国产精品| 国产美女搞久久| 日韩国产精品亚洲а∨天堂免| 中文字幕自拍vr一区二区三区| 欧美精品videos性欧美| 91最新在线免费观看| 欧美电影免费观看高清完整| 国产精品成人播放| 国产精品一区二区久久精品| 亚洲美女www午夜| 亚洲在线一区二区| 国产视频综合在线| 欧美老女人www| 亚洲电影免费观看高清完整版| 一区二区欧美激情| 欧美成人剧情片在线观看| 亚洲毛片在线观看.| 97精品国产91久久久久久| 亚洲成人在线网| 91久久国产综合久久91精品网站| 成人情趣片在线观看免费| 俺去亚洲欧洲欧美日韩| 欧美制服第一页| 日韩一级黄色av| 久久精品男人天堂| 伊人久久久久久久久久久| 成人av色在线观看| 91精品国产99| 久久久999精品视频| 国产精品免费在线免费| 日韩精品高清在线| 久久不射热爱视频精品| 欧美国产中文字幕| 成人免费看片视频| 亚洲欧美日韩天堂| 欧美日韩中国免费专区在线看| 精品国产视频在线| 国产精品第二页| 亚洲国产91精品在线观看| 日韩精品视频观看| 国产精品色午夜在线观看| 亚洲一区二区久久久| 国产一区二区三区在线观看网站| 精品亚洲男同gayvideo网站| 国产亚洲精品久久久久久777| 亚洲国产精彩中文乱码av在线播放| 亚洲色图在线观看| 午夜精品在线观看| 久久精视频免费在线久久完整在线看| 国产精品色午夜在线观看| 欧美激情欧美激情在线五月| 日韩av免费在线| 国产香蕉精品视频一区二区三区| 欧美xxxx18性欧美| 欧美亚洲在线观看| 国产在线精品播放| 国产精品青草久久久久福利99| 日韩av影片在线观看| 色偷偷偷亚洲综合网另类| 亚洲区中文字幕| 姬川优奈aav一区二区| 日本欧美一级片| 国产精品视频在线观看| 日韩av片永久免费网站| 亚洲国产日韩欧美在线99| 久久久精品久久久久| 国产精品96久久久久久又黄又硬| 亚洲一二三在线| 尤物精品国产第一福利三区| 国产91色在线免费| 国产成人极品视频| 欧美成人在线影院| 欧洲亚洲在线视频| 57pao成人国产永久免费| 97av在线视频免费播放| 国产成人久久久精品一区| 久久久久久久999| 亚洲精选在线观看| 欧美日韩加勒比精品一区| 久久久电影免费观看完整版| 浅井舞香一区二区| 欧美日韩中国免费专区在线看| 欧美大片免费观看在线观看网站推荐| 亚洲欧美国产一区二区三区| 亚洲欧美视频在线| 欧美激情综合色综合啪啪五月| 中文字幕日韩欧美精品在线观看| 久久国产精彩视频| 日韩欧美在线网址| 亚洲一级黄色av| 91成品人片a无限观看| 亚洲精品乱码久久久久久按摩观| 国产精品美女呻吟| 久久99精品视频一区97| 亚洲精品成人久久电影| 欧美一级在线播放| 精品偷拍各种wc美女嘘嘘| 国产日韩在线播放| 欧美日韩在线观看视频小说| 中日韩午夜理伦电影免费| 欧美人与物videos| 欧美日韩国产一区在线| 狠狠色狠狠色综合日日小说| 亚洲国产精品电影在线观看| 国内外成人免费激情在线视频| 亚洲自拍偷拍视频| 成人有码在线视频| 国产精品欧美日韩一区二区| 亚洲三级 欧美三级| 久久久av免费| 欧美亚洲第一页| 国产精品久久久久久久久久久新郎| 51久久精品夜色国产麻豆| 国产欧美日韩中文字幕| 亚洲成人免费网站| 中文字幕v亚洲ⅴv天堂| 亚洲欧美成人网| 亚洲精品日韩丝袜精品| 777午夜精品福利在线观看| 亚洲午夜精品久久久久久久久久久久| 91亚洲精品在线观看| 亚洲电影av在线| 亚洲天堂网站在线观看视频| 91网站在线看| 国产精品v片在线观看不卡| 国产成人啪精品视频免费网| 欧美亚洲午夜视频在线观看| 91精品久久久久久久久久| 538国产精品一区二区免费视频|