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

Oracle數(shù)據(jù)庫保持其優(yōu)良性的手段有哪些

數(shù)據(jù)庫 Oracle
以下的文章主要是講述使Oracle數(shù)據(jù)庫保持優(yōu)良性能的實際應(yīng)用方案,以下就有相關(guān)的應(yīng)用方案的介紹,希望會給你帶來一些幫助在此方面。

你如果想使Oracle數(shù)據(jù)庫保持其相關(guān)的優(yōu)良性能你就可以從下面的幾個方面來入手,即,分區(qū),重建相關(guān)的索引,以及相關(guān)段的碎片整理,以及 自由范圍的碎片整理等相關(guān)內(nèi)容的介紹,望你會有所收獲。

分區(qū)

根據(jù)實際經(jīng)驗,在一個大Oracle數(shù)據(jù)庫中,Oracle數(shù)據(jù)庫空間的絕大多數(shù)是被少量的表所占有。為了簡化大型數(shù)據(jù)庫的管理,改善應(yīng)用的查詢性能,一般可以使用分區(qū)這種手段。所謂分區(qū)就是動態(tài)地將表中的記錄分離到若干不同的表空間上,使數(shù)據(jù)在物理上被分割開來,便于維護(hù)、備份、恢復(fù)、事務(wù)及查詢性能。當(dāng)使用的時候可建立一個連接所有分區(qū)的視圖,使其在邏輯上仍以一個整體出現(xiàn)。

 

1. 建立分區(qū)表 

 

  1. Create table Employee (   
  2. EmpNo varchar2(10) primary key,   
  3. Name varchar2(30),   
  4. DeptNo Number(2)   
  5. )   
  6. Partition by range(DeptNo)   
  7. ( partition PART1 values less than (11)   
  8. tablespace PART1_TS,   
  9. partition PART2 values less than (21)   
  10. tablespace PART2_TS,   
  11. partition PART3 values less than (31)   
  12. tablespace PART3_TS   
  13. partition PART4 values less than (MAXvalue)   
  14. tablespace PART4_TS   
  15. );  

表Employee依據(jù)DeptNo列進(jìn)行分區(qū)。

 

 

2. 分區(qū)索引

 

 

  1. Create index Employee_DeptNo on Employee(DeptNo) local (   
  2. partition PART1 tablespace PART1_NDX_TS,   
  3. partition PART2 tablespace PART2_NDX_TS,   
  4. partition PART3 tablespace PART3_NDX_TS,   
  5. partition PART4 tablespace PART4_NDX_TS,   
  6. );   

當(dāng)分區(qū)中出現(xiàn)許多事務(wù)并且要保證所有分區(qū)中的數(shù)據(jù)記錄的惟一性時采用全局索引,在建立全局索引時,Global子句允許指定索引的范圍值,這個范圍值可以不同于表分區(qū)的范圍值。只有建立局部索引才會使索引分區(qū)與表分區(qū)間建立起一一對應(yīng)關(guān)系。因此,在大多數(shù)情況下,應(yīng)該使用局部索引分區(qū)。若使用了此索引,分區(qū)就能夠很容易地將索引分區(qū)與表分區(qū)建立關(guān)聯(lián),局部索引比全局索引更易于管理。

 

 

3. 分區(qū)管理

 

 

根據(jù)實際需要,還可以使用Alter table 命令來增加、刪除、交換、移動、修改、重命名、劃分、截短一個已存在分區(qū)的結(jié)構(gòu)。

 

 

重建索引

 

 

如果表中記錄頻繁地被刪除或插入,盡管表中的記錄總量保持不變,索引空間的使用量會不斷增加。雖然記錄從索引中被刪除,但是該記錄索引項的使用空間不能被重新使用。因此,如果表變化不定,索引空間量會不斷增加,不論表中記錄數(shù)量是否增加,只是因為索引中無效空間會增加。

 

 

要回收那些曾被刪除記錄使用的空間,需要使用Alter index rebuild 命令??梢宰鲆粋€定期運行的批處理程序,來重建最活動表的索引。這個批處理程序可以在空閑時運行,以避免該程序與其他應(yīng)用程序沖突。若能堅持索引的這一程序規(guī)劃,便可以及時回收那些未使用空間,提高空間利用率。

 

段的碎片整理

 

 

當(dāng)生成一個Oracle數(shù)據(jù)庫對象時(一個表或一個索引),通過用戶缺省值或指定值來為它指定表空間。一個在表空間中生成的段,用于存儲對象的相關(guān)數(shù)據(jù)。在段被關(guān)閉、收縮、截斷之前,段所分配的空間將不被釋放。

 

 

一個段是由范圍組成,而范圍是由相鄰的Oracle塊組成。一旦存在的范圍不能再存儲新的數(shù)據(jù),這個段就會去獲得新的范圍,但并不要求這些范圍是彼此相鄰的。這樣的擴展會一直繼續(xù)下去,直到表空間中的數(shù)據(jù)文件不能提供更多的自由空間,或者范圍數(shù)量已達(dá)到極限。

 

 

因此,一個碎片太多的數(shù)據(jù)段,不僅會影響運行,也會引發(fā)表空間中的空間管理問題。所以,每個數(shù)據(jù)段只含有一個范圍是十分有益的。借助監(jiān)控系統(tǒng),可以通過檢查DBA_SEGMENTS數(shù)據(jù)字典視圖來了解哪些Oracle數(shù)據(jù)庫對象含有10個或更多范圍的段,確定其數(shù)據(jù)段碎片。

 

 

若一個段的碎片過多,可用兩種方法解決:

 

 

(1) 用正確的存儲參數(shù)建立一個新表,將舊表中的數(shù)據(jù)插入到新表中,再刪除舊表;

 

 

(2) 利用Export/Import工具。

 

如:

 

  1. exp system/manager file=exp.dmp  
  2. compress=Y grants=Y indexes=Y   
  3. tables=(T1,T2) 

若輸出成功,進(jìn)入Oracle,刪除上述表。

 

注:compress=Y表示將在輸出過程中修改它們的存儲參數(shù)。

  1. imp system/manager file=exp.dmp commit=Y buffer=64000 full=Y 

注:在輸入時重新配置新的存儲參數(shù)。

 

自由范圍的碎片整理

 

 

表空間中的一個自由范圍是表空間中相連的自由(空間)塊的集合。當(dāng)一個段關(guān)閉時,它的范圍將被釋放,并被標(biāo)記為自由范圍。然而,這些自由范圍再也不能與相鄰的自由范圍合并,它們之間的界線始終存在。但是當(dāng)表空間的缺省值pctincrease設(shè)置不是0時,SMON后臺進(jìn)程會定期將這些相鄰的自由范圍合并。

若pctincrease設(shè)置為0,那么相鄰自由范圍不會被Oracle數(shù)據(jù)庫自動合并。但可以使用Alter table命令“coalesce”選項,來強迫進(jìn)行相鄰自由范圍的合并。

 

 

不進(jìn)行自由范圍合并,在日后的空間請求中,會影響到表空間中的空間分配。當(dāng)需要一個足夠大的范圍時,數(shù)據(jù)庫并不會合并相鄰的自由范圍,除非沒有其他選擇。這樣,當(dāng)表空間中前面較小的自由范圍已被使用時,將使用表空間中后面部分***的一個自由范圍。

結(jié)果,會因為沒有足夠多的使用空間,從而導(dǎo)致表空間需求的矛盾。由于這樣的情況出現(xiàn),使Oracle數(shù)據(jù)庫的空間分配距理想越來越遠(yuǎn)。自由空間碎片常會出現(xiàn)在那些經(jīng)常關(guān)閉又重新生成的數(shù)據(jù)庫表和索引中。

 

 

在理想的Oracle表空間中,每一個Oracle數(shù)據(jù)庫對象存儲在一個單獨的范圍中,并且所有有效自由空間集中在一個巨大而連續(xù)的范圍中。這樣,在一個對象需要附加存儲空間時,可以在增加獲取足夠大自由空間的可能性的同時,最小化空間中的循環(huán)調(diào)用,提高自由空間使用率。

 

文章出自:http://database.csdn.net/page/3e890491-bf4d-40db-a965-4c2e61d318fd 

【編輯推薦】

  1. Oracle游標(biāo)的打開與關(guān)閉
  2. 三個基本Oracle數(shù)據(jù)類型簡介
  3. Oracle游標(biāo)的打開與關(guān)閉
  4. 存儲結(jié)構(gòu)之Oracle邏輯存儲結(jié)構(gòu)
  5. Oracle數(shù)據(jù)庫的系統(tǒng)中6個經(jīng)驗原則

 

責(zé)任編輯:佚名 來源: csdn
相關(guān)推薦

2011-05-19 15:28:44

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

2011-03-23 14:09:50

Oracle數(shù)據(jù)

2010-04-19 15:21:37

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

2010-05-04 14:20:47

Oracle創(chuàng)建數(shù)據(jù)庫

2010-05-19 17:35:35

2010-04-22 09:42:00

2010-04-21 14:11:56

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

2010-04-16 15:05:10

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

2010-05-07 17:56:10

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

2010-04-22 12:15:30

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

2020-08-03 11:52:31

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

2010-04-19 15:09:10

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

2010-08-12 15:31:07

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

2010-07-05 14:04:00

SQL Server

2011-03-17 16:35:20

Oracle數(shù)據(jù)庫段管理

2011-03-17 16:19:42

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

2010-06-01 09:22:35

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

2010-05-05 15:52:36

Oracle 10G

2010-08-11 09:30:53

DB2常用函數(shù)

2018-02-07 17:09:05

Oracle云市場數(shù)據(jù)庫
點贊
收藏

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