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

Oracle的SQL調(diào)優(yōu)的目標(biāo)描述

數(shù)據(jù)庫(kù) Oracle
以下的文章主要是介紹Oracle SQL調(diào)優(yōu)的實(shí)際應(yīng)用以及Oracle SQL調(diào)優(yōu)的目標(biāo)是如何實(shí)現(xiàn)的,以下就是正文的詳細(xì)內(nèi)容的描述。

我們都知道Oracle的SQL調(diào)優(yōu)是很復(fù)雜的,如果想細(xì)致的了解它我們甚至以整本書(shū)的內(nèi)容來(lái)介紹Oracle SQL調(diào)優(yōu)的細(xì)微差別。但是有一些基本的規(guī)則是每個(gè)Oracle DBA都需要跟從的,這些規(guī)則可以改善他們系統(tǒng)的性能。

SQL調(diào)優(yōu)的目標(biāo)是簡(jiǎn)單的:

消除不必要的大表全表搜索:不必要的全表搜索導(dǎo)致大量不必要的I/O,從而拖慢整個(gè)數(shù)據(jù)庫(kù)的性能。調(diào)優(yōu)專(zhuān)家首先會(huì)根據(jù)查詢(xún)返回的行數(shù)目來(lái)評(píng)價(jià)SQL。在一個(gè)有序的表中,如果查詢(xún)返回少于40%的行,或者在一個(gè)無(wú)序的表中,返回少于7%的行,那么這個(gè)查詢(xún)都可以調(diào)整為使用一個(gè)索引來(lái)代替全表搜索。

對(duì)于不必要的全表搜索來(lái)說(shuō),最常見(jiàn)的調(diào)優(yōu)方法是增加索引??梢栽诒碇屑尤霕?biāo)準(zhǔn)的B樹(shù)索引,也可以加入bitmap和基于函數(shù)的索引。要決定是否消除一個(gè)全表搜索,你可以仔細(xì)檢查索引搜索的I/O開(kāi)銷(xiāo)和全表搜索的開(kāi)銷(xiāo),它們的開(kāi)銷(xiāo)和數(shù)據(jù)塊的讀取和可能的并行執(zhí)行有關(guān),并將兩者作對(duì)比。

在一些情況下,一些不必要的全表搜索的消除可以通過(guò)強(qiáng)制使用一個(gè)index來(lái)達(dá)到,只需要在SQL語(yǔ)句中加入一個(gè)索引的提示就可以了。

在全表搜索是一個(gè)最快的訪問(wèn)方法時(shí),將小表的全表搜索放到緩存中,調(diào)優(yōu)專(zhuān)家應(yīng)該確保有一個(gè)專(zhuān)門(mén)的數(shù)據(jù)緩沖用作行緩沖。在Oracle7中,你可以使用alter table xxx cache語(yǔ)句,在Oracle8或以上,小表可以被強(qiáng)制為放到KEEP池中緩沖。

確保***的索引使用 :對(duì)于改善查詢(xún)的速度,這是特別重要的。有時(shí)Oracle可以選擇多個(gè)索引來(lái)進(jìn)行查詢(xún),調(diào)優(yōu)專(zhuān)家必須檢查每個(gè)索引并且確保Oracle使用正確的索引。它還包括bitmap和基于函數(shù)的索引的使用。

確保***的JOIN操作:有些查詢(xún)使用NESTED LOOP join快一些,有些則是HASH join快一些,另外一些則是sort-merge join更快。

這些規(guī)則看來(lái)簡(jiǎn)單,不過(guò)它們占Oracle SQL調(diào)優(yōu)任務(wù)的90%,并且它們也無(wú)需完全懂得Oracle SQL的內(nèi)部運(yùn)作。以下我們來(lái)簡(jiǎn)單概覽以下Oracle SQL的優(yōu)化。

我們首先簡(jiǎn)要查看Oracle的排序,并且看一看排序操作是如何影響性能的。

調(diào)整Oracle的排序操作

排序是SQL語(yǔ)法中一個(gè)小的方面,但很重要,在Oracle的調(diào)整中,它常常被忽略。當(dāng)使用create index、ORDER BY或者GROUP BY的語(yǔ)句時(shí),Oracle數(shù)據(jù)庫(kù)將會(huì)自動(dòng)執(zhí)行排序的操作。通常,在以下的情況下Oracle會(huì)進(jìn)行排序的操作:

使用Order by的SQL語(yǔ)句。

使用Group by的SQL語(yǔ)句。

在創(chuàng)建索引的時(shí)候進(jìn)行table join時(shí),由于現(xiàn)有索引的不足而導(dǎo)致Oracle SQL調(diào)優(yōu)用MERGE SORT。當(dāng)與Oracle建立起一個(gè)session時(shí),在內(nèi)存中就會(huì)為該session分配一個(gè)私有的排序區(qū)域。如果該連接是一個(gè)專(zhuān)用的連接(dedicated connection),那么就會(huì)根據(jù)init.ora中sort_area_size參數(shù)的大小在內(nèi)存中分配一個(gè)Program Global Area (PGA) 。

如果連接是通過(guò)多線程服務(wù)器建立的,那么排序的空間就在large_pool中分配。不幸的是,對(duì)于所有的session,用做排序的內(nèi)存量都必須是一樣的,我們不能為需要更大排序的操作分配額外的排序區(qū)域。

因此,設(shè)計(jì)者必須作出一個(gè)平衡,在分配足夠的排序區(qū)域以避免發(fā)生大的排序任務(wù)時(shí)出現(xiàn)磁盤(pán)排序(disk sorts)的同時(shí),對(duì)于那些并不需要進(jìn)行很大排序的任務(wù),就會(huì)出現(xiàn)一些浪費(fèi)。當(dāng)然,當(dāng)排序的空間需求超出了sort_area_size的大小時(shí),這時(shí)將會(huì)在TEMP表空間中分頁(yè)進(jìn)行磁盤(pán)排序。磁盤(pán)排序要比內(nèi)存排序大概慢14,000倍。

上面我們已經(jīng)提到,私有排序區(qū)域的大小是有init.ora中的sort_area_size參數(shù)決定的。每個(gè)排序所占用的大小由init.ora中的sort_area_retained_size參數(shù)決定。當(dāng)排序不能在分配的空間中完成時(shí),就會(huì)使用磁盤(pán)排序的方式,即在Oracle實(shí)例中的臨時(shí)表空間中進(jìn)行。

磁盤(pán)排序的開(kāi)銷(xiāo)是很大的,有幾個(gè)方面的原因。首先,和內(nèi)存排序相比較,它們特別慢;而且磁盤(pán)排序會(huì)消耗臨時(shí)表空間中的資源。Oracle還必須分配緩沖池塊來(lái)保持臨時(shí)表空間中的塊。無(wú)論什么時(shí)候,內(nèi)存排序都比磁盤(pán)排序好,磁盤(pán)排序?qū)?huì)令任務(wù)變慢,并且會(huì)影響Oracle實(shí)例的當(dāng)前任務(wù)的執(zhí)行。

還有,過(guò)多的磁盤(pán)排序?qū)?huì)令free buffer waits的值變高,從而令其它任務(wù)的數(shù)據(jù)塊由緩沖中移走。

【編輯推薦】

  1. 配置Oracle RAC中應(yīng)注意的問(wèn)題有哪些
  2. Oracle自增字段的實(shí)際應(yīng)用
  3. Oracle使用游標(biāo)觸發(fā)器存儲(chǔ)實(shí)操
  4. Oracle數(shù)據(jù)庫(kù)中表的不同的連接方式描述
  5. Oracle數(shù)據(jù)庫(kù)中表的連接方式的講解
責(zé)任編輯:佚名 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-04-22 16:39:21

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

2010-07-19 13:35:51

SQL Server性

2009-11-17 13:45:12

Oracle SQL調(diào)

2010-04-19 13:50:27

Oracle調(diào)整

2011-05-20 14:23:01

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

2010-04-15 16:16:33

Oracle SQL

2011-05-20 15:02:01

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

2011-05-18 10:16:24

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

2023-11-10 09:25:36

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

2010-04-09 10:32:03

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

2010-08-11 14:32:55

DB2數(shù)據(jù)庫(kù)調(diào)優(yōu)

2010-08-11 12:43:45

DB2數(shù)據(jù)庫(kù)調(diào)優(yōu)

2010-05-05 14:04:31

Oracle 性能

2011-03-10 14:40:54

LAMPMysql

2010-04-09 10:43:34

Oracle SQL

2010-05-04 17:08:24

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

2022-02-28 10:11:22

查詢(xún)數(shù)據(jù)SQL

2011-09-02 14:05:25

SQL Server性能調(diào)優(yōu)

2009-11-09 17:27:38

Oracle編碼SQL

2009-07-17 17:16:44

Swing實(shí)現(xiàn)的目標(biāo)
點(diǎn)贊
收藏

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