優化Oracle庫表設計的若干方法(二)

 優化設計

  1、將表數據和索引數據分開表空間存儲

  1.1 表數據和索引爲何需要使用獨立的表空間

  Oracle強烈建立,任何一個應用程序的庫表至少需要創建兩個表空間,其中之一用於存儲表數據,而另一個用於存儲表索引數據。因爲如果將表數據和索引數據放在一起,表數據的I/O操作和索引的I/O操作將產生影響系統性能的I/O競爭,降低系統的響應效率。將表數據和索引數據存放在不同的表空間中(如一個爲APP_DATA,另一個爲APP_IDX),並在物理層面將這兩個表空間的數據文件放在不同的物理磁盤上,就可以避免這種競爭了。

  擁有獨立的表空間,就意味着可以獨立地爲表數據和索引數據提供獨立的物理存儲參數,而不會發生相互影響,畢竟表數據和索引數據擁有不同的特性,而這些特性又直接影響了物理存儲參數的設定。

  此外,表數據和索引數據獨立存儲,還會帶來數據管理和維護上的方面。如你在遷移一個業務數據庫時,爲了降低數據大小,可以只遷出表數據的表空間,在目標數據庫中通過重建索引的方式就可以生成索引數據了。

  1.2 表數據和索引使用不同表空間的SQL語法

  指定表數據及索引數據存儲表空間語句最簡單的形式如下。

  將表數據存儲在APP_DATA表空間裏:

create table T_ORDER ( ORDER_ID NUMBER(10) not null, …)tablespace APP_DATA;

  將索引數據存儲在APP_IDX表空間裏:

create index IDX_ORDER_ITEM_ORDER_ID on T_ORDER_ITEM ( ORDER_ID ASC)tablespace APP_IDX;

  1.3 PowerDesigner中如何操作

  1) 首先,必須創建兩個表空間。通過Model->Tablespace...在List of Tablespaces中創建兩個表空間:


圖 2 創建表空間

  2) 爲每張表指定表數據存儲的表空間。在設計區中雙擊表,打開Table Properties設計窗口,切換到options 頁,按圖 3所示指定表數據的存儲表空間。

http://soft.yesky.com/imagelist/05/10/702tubt04d5j.jpg
圖 3 指定表數據的存儲表空間

  3) 爲每個索引指定索引數據的存儲表空間。在Table Properties中切換到Indexes頁,在這裏列出了表的所有索引,雙擊需設置表空間的索引,在彈出的Index Properties窗口中切換到Options頁,按如下方式指定索引的存儲表空間。


圖 4 指定索引數據的存儲表空間

  將表空間的問題延展一下:一個應用系統庫表的表空間可以進行更精細的劃分。

  首先,如果表中存在LOB類型的字段,有爲其指定一個特定的表空間,因爲LOB類型的數據在物理存儲結構的管理上和一般數據的策略有很大的不同,將其放在一個獨立的表空間中,就可方便地設置其物理存儲參數了。

  其次,需要考慮庫表數據的DML操作特性:根據DML(INSERT,UPDATE,DELETE)操作頻繁程度,將幾乎不發生任何DML操作的數據放在獨立的表空間中,因爲極少DML操作的表可設置符合其特性的物理參數:如PCTFREE可置爲0,其BUFFER_POOL指定爲KEEP,以便將數據緩存在KEEP數據緩存區中等等,不一而足。

  此外,還可以考慮按業務需要將不同的業務模塊分開存放,這主要是考慮到備份問題。假設我們有一部分業務數據重要性很強,而其他的業務數據重要性相對較弱,這樣就可以將兩者分開存儲,以便設置不同的備份策略。

  當然,無節制的細化表空間也將帶來管理上和部署上的複雜,根據業務需求合理地規劃表空間以達到管理和性能上的最佳往往需要更多的權衡。
發佈了79 篇原創文章 · 獲贊 1 · 訪問量 27萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章