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

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

Oracle數(shù)據(jù)庫最優(yōu)化參數(shù)縮短反應(yīng)時間

2024-08-29 13:50:56
字體:
供稿:網(wǎng)友
在Oracle9i之前,僅有的兩個CBO模式是ALL_ROWS以及FIRST_ROWS。傳統(tǒng)的FIRST_ROWS SQL最優(yōu)化的缺點之一是,它的運算法則并沒有非凡指定行檢索的范圍。 但是,在Oracle9i中包含了幾個新的最優(yōu)化指令:
  FIRST_ROWS_1   FIRST_ROWS_10   FIRST_ROWS_100   FIRST_ROWS_1000   FIRST_ROWS_n
最優(yōu)化會指示選擇一個查詢執(zhí)行計劃,這個計劃會縮短生成最初n行查詢結(jié)果的時間。 你可以把這個新的CBO模式設(shè)置到數(shù)據(jù)庫中的幾個層次上:systemwide,在會話層或者在查詢層次上。
  alter system set optimizer_mode=first_rows_100;  alter session set optimizer_mode = first_rows_100;  select /*+ first_rows(100) */ from student;
根據(jù)來自O(shè)racle公司的說法,使用FIRST_ROWS_n最優(yōu)化,Oracle查詢能夠使用最少的反應(yīng)時間來給出最初的n行結(jié)果。更快速的給出最初n行的結(jié)果能夠提高用戶對應(yīng)用軟件的滿足程度的原因是由于用戶能夠更為快速的得到最初的那些數(shù)據(jù)。 當使用FIRST_ROWS最優(yōu)化索引的時候,ALL_ROWS最優(yōu)化支持完整表的搜尋。但是,Oracle通過FIRST_ROWS_n最優(yōu)化擴展了這個概念的范疇。 在傳統(tǒng)的FIRST_ROWS最優(yōu)化中,Oracle CBO支持索引掃描,甚至當全部成本高于完整表掃描的時候也是如此。在對于完整表掃描不太昂貴的較小型表的情況下,這種情況也是尤為明顯。 請看一看下面的這個例子。
  Set autotrace on eXPlain  alter session set optimizer_goal = choose;  select * from emp where sal < 1200;  PLAN   SELECT STATEMENT (OPTIMIZER=CHOOSE) (COST=62) (ROWS=99)  TABLE access FULL EMP (COST=62) (ROWS=99)
現(xiàn)在,我們要使用FIRST_ROWS最優(yōu)化來進行相同的查詢工作。
  alter session set optimizer_goal = first_rows;  select * from emp where sal < 1200;  The explain plan is now transformed to:  PLAN   SELECT STATEMENT (OPTIMIZER=FIRST_ROWS) (COST=102)  TABLE ACCESS BY INDEX ROWID EMP (COST=102) (ROWS=99)  INDEX RANGE SCAN SA L_IDX (COST=2) (ROWS=99)
我們希望CBO能夠?qū)λ饕M行支持,但是我們還是非常驚異的看到選擇了一種比完整表掃描更為昂貴的方式。這是一個臨界點。在Oracle9i之前,F(xiàn)IRST_ROWS最優(yōu)化是一種對內(nèi)部規(guī)則和費用的一種綜合,而且Oracle9i FIRST_ROWS最優(yōu)化也是完全基于成本的。 在Oracle9i之前,我們使用OPTIMIZER_INDEX_COST_ADJ參數(shù)來控制CBO選擇索引。雖然Oracle公司聲稱FIRST_ROWS_n最優(yōu)化能夠讓查詢變得更加快速,但是要記住, Oracle9i CBO所負責的是最初那些行的查詢訪問的成本。換一種說法,所有的FIRST_ROWS_n模式所做的就是決定出更為明智的選擇,決定是使用索引還是使用完整表掃描來進行對小型表的訪問。由于多數(shù)的Oracle9i DBA會把這些小型表存儲于KEEP池中,因此該參數(shù)使用的范圍并不廣。


上一篇:怎樣自動將數(shù)據(jù)導(dǎo)入 Oracle數(shù)據(jù)庫

下一篇:用腳本和查詢來主動監(jiān)視Oracle的性能

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
學(xué)習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網(wǎng)友關(guān)注

主站蜘蛛池模板: 河北省| 依兰县| 台东县| 白玉县| 临猗县| 都匀市| 泰和县| 新津县| 淮北市| 江源县| 信阳市| 昌图县| 洞头县| 浙江省| 巫溪县| 阳山县| 甘肃省| 香格里拉县| 堆龙德庆县| 三都| 汉源县| 昌黎县| 丰原市| 荔浦县| 西畴县| 额济纳旗| 册亨县| 隆尧县| 延庆县| 陆丰市| 兴义市| 蓝山县| 蕉岭县| 东安县| 双辽市| 定州市| 石楼县| 嵊州市| 朔州市| 万山特区| 普定县|