亚洲香蕉成人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
欧美风情在线观看| 亚洲天堂男人的天堂| 国产精品视频自在线| 久久久久久香蕉网| 久久国产精品久久久| 日韩中文字幕在线| 成人观看高清在线观看免费| 成人综合国产精品| 国产亚洲精品va在线观看| 日韩高清电影免费观看完整版| 久久久久久久影院| 日韩av在线网页| 日韩精品一区二区视频| 精品国产依人香蕉在线精品| 久久精品视频播放| 欧美怡红院视频一区二区三区| 97超碰蝌蚪网人人做人人爽| 国产精品海角社区在线观看| 国产精品第1页| 日本欧美中文字幕| 欧美日韩免费一区| 亚洲男人第一av网站| 国产成人精品综合久久久| 久久精品国产2020观看福利| 亚洲成人黄色在线| 日本在线观看天堂男亚洲| 久久全球大尺度高清视频| 国产欧美日韩视频| 成人淫片在线看| 日韩电影在线观看免费| 国产精品入口免费视| 91av成人在线| 欧美日韩性视频在线| 午夜精品一区二区三区在线视| 欧美激情成人在线视频| 成人观看高清在线观看免费| 欧美日韩国产精品一区| 欧美日韩国产精品一区二区三区四区| 69视频在线播放| 欧美国产高跟鞋裸体秀xxxhd| 在线丨暗呦小u女国产精品| 亚洲电影免费观看高清完整版在线| 亚洲国产精品va在线观看黑人| 色综合久久88| 国产精品亚洲一区二区三区| 亚洲一区二区三区四区在线播放| 亚洲美女av网站| 亚洲淫片在线视频| 97超视频免费观看| 亚洲视频精品在线| 91国偷自产一区二区三区的观看方式| 最近中文字幕2019免费| 国产精品嫩草影院一区二区| 黑人狂躁日本妞一区二区三区| 日韩精品视频在线观看免费| 亚洲国产欧美自拍| 一区二区三区久久精品| 欧美亚洲日本网站| 亚洲激情在线视频| 久久精品免费播放| 亚洲老头同性xxxxx| 欧美日韩不卡合集视频| 最近2019年好看中文字幕视频| 久久不射热爱视频精品| 成人网在线免费观看| 亚洲成在人线av| 欧美日韩免费网站| 岛国av在线不卡| 欧美性视频网站| 欧美区二区三区| 国内精品中文字幕| 欧美老女人在线视频| 日韩精品久久久久久久玫瑰园| 欧洲美女免费图片一区| 亚洲人成绝费网站色www| 欧美尺度大的性做爰视频| 亚洲另类激情图| 久久国产精品久久久久久| 中日韩美女免费视频网址在线观看| 国产一区二区三区精品久久久| 欧美大片在线免费观看| 成人在线激情视频| 国产一区二区日韩| 国产福利视频一区| 成人性生交大片免费看小说| 欧美激情精品在线| 日韩欧美精品免费在线| 日韩第一页在线| 国产亚洲欧洲高清| 成人免费在线视频网站| 国产69精品久久久久久| 精品精品国产国产自在线| 日韩亚洲欧美中文在线| 欧美激情视频在线| 91在线视频精品| 91国产中文字幕| 色樱桃影院亚洲精品影院| 国产美女精品免费电影| 亚洲一区二区三区香蕉| 亚洲欧美三级伦理| 久久久久久12| 色偷偷888欧美精品久久久| 亚洲在线观看视频| 亚洲精品一区二区三区婷婷月| 91亚洲精品久久久久久久久久久久| 欧美色视频日本高清在线观看| 热久久这里只有精品| 欧美日韩国产一区二区| 国产精品一区二区性色av| 国产视频亚洲精品| 欧美高清视频一区二区| 欧美一区二区视频97| 久热精品视频在线观看一区| 日本精品久久中文字幕佐佐木| 91国自产精品中文字幕亚洲| 国产一区二区日韩精品欧美精品| 亚洲黄色免费三级| 在线观看欧美成人| 日韩av在线网址| 亚洲成人免费在线视频| 亚洲sss综合天堂久久| 国产亚洲精品高潮| 亚洲欧美国产日韩中文字幕| 国产精品亚洲аv天堂网| 中文日韩电影网站| 国产男女猛烈无遮挡91| 成人在线免费观看视视频| 日本免费久久高清视频| 国内外成人免费激情在线视频网站| 成人精品一区二区三区| 欧美成人精品不卡视频在线观看| 欧美在线一级视频| www.久久色.com| 欧洲s码亚洲m码精品一区| 日韩的一区二区| 亚洲最大av在线| 欧美日韩国产区| 国产欧美欧洲在线观看| 国产久一一精品| 2019中文字幕在线观看| 精品久久久国产| 国产在线播放不卡| 亚洲精品二三区| 亲爱的老师9免费观看全集电视剧| 色与欲影视天天看综合网| 国产亚洲人成a一在线v站| 欧美成人三级视频网站| 911国产网站尤物在线观看| 国产成人在线一区| 国内免费久久久久久久久久久| 国产精品高潮在线| 91精品在线影院| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品久久久久av免费| 欧美日韩中文在线| 色综合伊人色综合网| 91久久久久久久久久| 88xx成人精品| 亚洲码在线观看| 欧美日韩国产999| 久久久久九九九九| 国产欧美一区二区三区久久| 亚洲一区二区三区香蕉| 91理论片午午论夜理片久久|