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

保持Oracle數(shù)據(jù)優(yōu)良性能的若干訣竅

數(shù)據(jù)庫(kù) Oracle
oracle數(shù)據(jù)庫(kù)是一種大型數(shù)據(jù)庫(kù)系統(tǒng),一般應(yīng)用于商業(yè),政府部門(mén),它的功能很強(qiáng)大,能夠處理大批量的數(shù)據(jù),在網(wǎng)絡(luò)方面也用的非常多。oracle數(shù)據(jù)庫(kù)性能優(yōu)良,那么如何保持Oracle數(shù)據(jù)庫(kù)的優(yōu)良性能?

導(dǎo)讀Oracle數(shù)據(jù)庫(kù)以其高可靠性、安全性、可兼容性,得到越來(lái)越多的企業(yè)的青睞。如何使Oracle數(shù)據(jù)庫(kù)保持優(yōu)良性能,這是許多數(shù)據(jù)庫(kù)管理員關(guān)心的問(wèn)題,下文中為大家介紹了幾點(diǎn),大家可以參考著從以下幾個(gè)方面加以考慮。

一、分區(qū)

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

  1. 建立分區(qū)表

Create table Employee (
EmpNo varchar2(10) primary key,
Name varchar2(30),
DeptNo Number(2)
)
Partition by range(DeptNo)
( partition PART1 values less than (11)
tablespace PART1_TS,
partition PART2 values less than (21)
tablespace PART2_TS,
partition PART3 values less than (31)
tablespace PART3_TS
partition PART4 values less than (MAXvalue)
tablespace PART4_TS
);

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

  2. 分區(qū)索引

Create index Employee_DeptNo on Employee(DeptNo) local (
partition PART1 tablespace PART1_NDX_TS,
partition PART2 tablespace PART2_NDX_TS,
partition PART3 tablespace PART3_NDX_TS,
partition PART4 tablespace PART4_NDX_TS,
);

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

  3. 分區(qū)管理

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

二、重建索引

  如果表中記錄頻繁地被刪除或插入,盡管表中的記錄總量保持不變,索引空間的使用量會(huì)不斷增加。雖然記錄從索引中被刪除,但是該記錄索引項(xiàng)的使用空間不能被重新使用。因此,如果表變化不定,索引空間量會(huì)不斷增加,不論表中記錄數(shù)量是否增加,只是因?yàn)樗饕袩o(wú)效空間會(huì)增加。

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

三、段的碎片整理

  當(dāng)生成一個(gè)數(shù)據(jù)庫(kù)對(duì)象時(shí)(一個(gè)表或一個(gè)索引),通過(guò)用戶(hù)缺省值或指定值來(lái)為它指定表空間。一個(gè)在表空間中生成的段,用于存儲(chǔ)對(duì)象的相關(guān)數(shù)據(jù)。在段被關(guān)閉、收縮、截?cái)嘀?,段所分配的空間將不被釋放。

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

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

  若一個(gè)段的碎片過(guò)多,可用兩種方法解決:

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

  2. 利用Export/Import工具。

  如:

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

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

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

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

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

四、自由范圍的碎片整理

  表空間中的一個(gè)自由范圍是表空間中相連的自由(空間)塊的集合。當(dāng)一個(gè)段關(guān)閉時(shí),它的范圍將被釋放,并被標(biāo)記為自由范圍。然而,這些自由范圍再也不能與相鄰的自由范圍合并,它們之間的界線(xiàn)始終存在。但是當(dāng)表空間的缺省值pctincrease設(shè)置不是0時(shí),SMON后臺(tái)進(jìn)程會(huì)定期將這些相鄰的自由范圍合并。若pctincrease設(shè)置為0,那么相鄰自由范圍不會(huì)被數(shù)據(jù)庫(kù)自動(dòng)合并。但可以使用Alter table命令“coalesce”選項(xiàng),來(lái)強(qiáng)迫進(jìn)行相鄰自由范圍的合并。

  不進(jìn)行自由范圍合并,在日后的空間請(qǐng)求中,會(huì)影響到表空間中的空間分配。當(dāng)需要一個(gè)足夠大的范圍時(shí),數(shù)據(jù)庫(kù)并不會(huì)合并相鄰的自由范圍,除非沒(méi)有其他選擇。這樣,當(dāng)表空間中前面較小的自由范圍已被使用時(shí),將使用表空間中后面部分最大的一個(gè)自由范圍。結(jié)果,會(huì)因?yàn)闆](méi)有足夠多的使用空間,從而導(dǎo)致表空間需求的矛盾。由于這樣的情況出現(xiàn),使數(shù)據(jù)庫(kù)的空間分配距理想越來(lái)越遠(yuǎn)。自由空間碎片常會(huì)出現(xiàn)在那些經(jīng)常關(guān)閉又重新生成的數(shù)據(jù)庫(kù)表和索引中。

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

【編輯推薦】

  1. 輕松解決Oracle數(shù)據(jù)庫(kù)的服務(wù)啟動(dòng)問(wèn)題
  2. 數(shù)據(jù)訪(fǎng)問(wèn)由SQL Server遷移向Oracle數(shù)據(jù)庫(kù)的問(wèn)題整理
  3. 入侵Oracle數(shù)據(jù)庫(kù)常用操作命令
責(zé)任編輯:迎迎 來(lái)源: linuxdiyf.com 
相關(guān)推薦

2011-05-19 15:28:44

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

2010-04-22 17:27:04

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

2010-04-19 15:21:37

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

2022-03-30 07:52:16

.NET應(yīng)用程序C#

2016-10-25 13:46:25

深度學(xué)習(xí)機(jī)器學(xué)習(xí)性能提升

2011-03-30 16:36:58

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

2009-12-03 14:52:27

2012-04-06 14:28:01

神舟

2010-04-13 16:08:24

Oracle數(shù)據(jù)插入

2012-09-11 11:08:23

Github系統(tǒng)

2013-06-07 17:53:44

桌面虛擬化云終端

2019-01-18 09:50:14

物聯(lián)網(wǎng)數(shù)據(jù)IOT

2010-10-09 10:05:04

2013-05-07 09:01:39

2016-10-17 14:29:01

數(shù)據(jù)中心恒溫恒濕“智”冷

2018-12-24 09:00:00

測(cè)試工具Flood Eleme

2010-06-17 12:59:07

Oracle

2023-08-29 15:10:04

持續(xù)性能優(yōu)化開(kāi)發(fā)

2010-11-15 16:13:24

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

2010-05-07 17:39:02

Oracle數(shù)據(jù)庫(kù)性能
點(diǎn)贊
收藏

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