成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

數(shù)據(jù)庫 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ì)致的了解它我們甚至以整本書的內(nè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ù)庫的性能。調(diào)優(yōu)專家首先會(huì)根據(jù)查詢返回的行數(shù)目來評(píng)價(jià)SQL。在一個(gè)有序的表中,如果查詢返回少于40%的行,或者在一個(gè)無序的表中,返回少于7%的行,那么這個(gè)查詢都可以調(diào)整為使用一個(gè)索引來代替全表搜索。

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

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

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

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

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

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

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

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

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

使用Order by的SQL語句。

使用Group by的SQL語句。

在創(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è)專用的連接(dedicated connection),那么就會(huì)根據(jù)init.ora中sort_area_size參數(shù)的大小在內(nèi)存中分配一個(gè)Program Global Area (PGA) 。

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

因此,設(shè)計(jì)者必須作出一個(gè)平衡,在分配足夠的排序區(qū)域以避免發(fā)生大的排序任務(wù)時(shí)出現(xiàn)磁盤排序(disk sorts)的同時(shí),對(duì)于那些并不需要進(jìn)行很大排序的任務(wù),就會(huì)出現(xiàn)一些浪費(fèi)。當(dāng)然,當(dāng)排序的空間需求超出了sort_area_size的大小時(shí),這時(shí)將會(huì)在TEMP表空間中分頁進(jì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ì)使用磁盤排序的方式,即在Oracle實(shí)例中的臨時(shí)表空間中進(jìn)行。

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

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

【編輯推薦】

  1. 配置Oracle RAC中應(yīng)注意的問題有哪些
  2. Oracle自增字段的實(shí)際應(yīng)用
  3. Oracle使用游標(biāo)觸發(fā)器存儲(chǔ)實(shí)操
  4. Oracle數(shù)據(jù)庫中表的不同的連接方式描述
  5. Oracle數(shù)據(jù)庫中表的連接方式的講解
責(zé)任編輯:佚名 來源: 互聯(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-18 10:16:24

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

2011-05-20 15:02:01

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

2010-04-09 10:32:03

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

2023-11-10 09:25:36

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

2010-08-11 14:32:55

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

2010-05-05 14:04:31

Oracle 性能

2011-03-10 14:40:54

LAMPMysql

2010-08-11 12:43:45

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

2010-04-09 10:43:34

Oracle SQL

2009-11-09 17:27:38

Oracle編碼SQL

2010-05-04 17:08:24

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

2009-07-17 17:16:44

Swing實(shí)現(xiàn)的目標(biāo)

2022-02-28 10:11:22

查詢數(shù)據(jù)SQL

2011-09-02 14:05:25

SQL Server性能調(diào)優(yōu)
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 免费人成激情视频在线观看冫 | 欧美日韩国产一区二区三区 | 中文字幕在线观看视频一区 | 久久精品欧美一区二区三区不卡 | 成人网在线观看 | 国产精品久久毛片av大全日韩 | 成人免费一区二区三区牛牛 | 国产精品视频导航 | 久久久久久久久久久久久9999 | 亚洲一区三区在线观看 | 久久天天综合 | 欧美精品久久 | 欧美一区二区在线观看视频 | 伊人色综合久久久天天蜜桃 | 久久黄视频| 午夜视频免费在线观看 | 精品国产乱码久久久久久蜜退臀 | 国产精品久久久久久久久久三级 | 麻豆久久久久久久久久 | 亚洲欧美日韩中文字幕一区二区三区 | 你懂的在线视频播放 | 日韩精品在线看 | 亚洲精品一区二三区不卡 | 黑人成人网 | 日日欧美 | 国产精品毛片一区二区三区 | 二区精品 | 欧美日韩高清在线一区 | 国产精品视频综合 | 国产成人精品福利 | 天堂成人国产精品一区 | 国产精品视屏 | 亚洲精品在线视频 | av中文字幕网 | 99精品国产一区二区三区 | 正在播放国产精品 | 黄色综合 | 天天干天天插 | 日韩欧美精品一区 | 欧美八区 | 欧美亚洲另类丝袜综合网动图 |