談談怎么實現(xiàn)Oracle數(shù)據(jù)庫分區(qū)表 |
發(fā)布時間: 2012/8/21 16:57:15 |
Oracle數(shù)據(jù)庫分區(qū)是作為Oracle數(shù)據(jù)庫性能優(yōu)化的一種重要的手段和方法,做手頭的項目以前,只聆聽過分區(qū)的大名,感覺特神秘,看見某某高手在討論會上夸夸其談時,真是罵自己學藝不精,最近作GPS方面的項目,處理的數(shù)據(jù)量達到了幾十GB,為了滿足系統(tǒng)的實時性要求,必須提高數(shù)據(jù)的查詢效率,這樣就必須通過分區(qū),以解燃眉之急! 先說說分區(qū)的好處吧! 1) 增強可用性:如果表的某個分區(qū)出現(xiàn)故障,表在其他分區(qū)的數(shù)據(jù)仍然可用; 2) 維護方便:如果表的某個分區(qū)出現(xiàn)故障,需要修復數(shù)據(jù),只修復該分區(qū)即可; 3) 均衡I/O:可以把不同的分區(qū)映射到磁盤以平衡I/O,改善整個系統(tǒng)性能; 4) 改善查詢性能:對分區(qū)對象的查詢可以僅搜索自己關心的分區(qū),提高檢索速度。 Oracle數(shù)據(jù)庫提供對表或索引的分區(qū)方法有三種: ü 范圍分區(qū) ü Hash分區(qū)(散列分區(qū)) ü 復合分區(qū) 一、范圍分區(qū)詳細說明 范圍分區(qū)就是對數(shù)據(jù)表中的某個值的范圍進行分區(qū),根據(jù)某個值的范圍,決定將該數(shù)據(jù)存儲在哪個分區(qū)上。如根據(jù)序號分區(qū),根據(jù)時間等來進行分區(qū)。根據(jù)序號,比如小于2000000的放在part01, 2000000~4000000的放在part02。。。 create table AAA space01\ space02\ space03為建立的三個表空間,相當于把建立的一個大的表分在了3個不同的表空間的分區(qū)上了。 二、Hash分區(qū)(散列分區(qū))詳細說明 散列分區(qū)為通過指定分區(qū)編號來均勻分布數(shù)據(jù)的一種分區(qū)類型,因為通過在I/O設備上進行散列分區(qū),使得這些分區(qū)大小一致。也就是只命名分區(qū)名稱,這樣均勻進行數(shù)據(jù)分布。 三、復合分區(qū)詳細說明 有時候我們需要根據(jù)范圍分區(qū)后,每個分區(qū)內(nèi)的數(shù)據(jù)再散列地分布在幾個表空間中,這樣我們就要使用復合分區(qū)。復合分區(qū)是先使用范圍分區(qū),然后在每個分區(qū)內(nèi)再使用散列分區(qū)的一種分區(qū)方法。 partition by range(indate)subpartition by hash(id) 四、分區(qū)表操作 1、插入記錄:insert into AAA values(1 ,sysdate); 2、查詢分區(qū)表記錄:select * from AAA partition(part_01); 3、更新分區(qū)表的記錄:update AAA partition(part_01) t set indate=’’where id=1; 但是當更新的時候指定了分區(qū),而根據(jù)查詢的記錄不在該分區(qū)中時,將不會更新數(shù)據(jù) 4、刪除分區(qū)表記錄:delete from AAA partition(part_02) t where id=4; 如果指定了分區(qū),而條件中的數(shù)據(jù)又不在該分區(qū)中時,將不會刪除任何數(shù)據(jù)。 5、增加一個分區(qū):alter table AAA add partition part_04 values less than(to_date(’2012-01-01’,’yyyy-mm-dd’)) tablespace dinya_spa ce03; 增加一個分區(qū)的時候,增加的分區(qū)的條件必須大于現(xiàn)有分區(qū)的最大值,否則系統(tǒng)將提示ORA-14074 partition bound must collate higher than that of the last partition 錯誤。 6、合并一個分區(qū):alter table AAA merge partitions part_01,part_02 into partition part_02; ,如果在合并的時候把合并后的分區(qū)定為part_01的時候,系統(tǒng)將提示ORA-14275 cannot reuse lower-bound partition as resulting partition 錯誤。 7、刪除分區(qū):alter table AAA drop partition part_01; 刪除分區(qū)表的一個分區(qū)后,查詢該表的數(shù)據(jù)時顯示,該分區(qū)中的數(shù)據(jù)已全部丟失,所以執(zhí)行刪除分區(qū)動作時要慎重,確保先備份數(shù)據(jù)后再執(zhí)行,或將分區(qū)合并。 五、建立索引 分區(qū)表和一般表一樣可以建立索引,分區(qū)表可以創(chuàng)建局部索引和全局索引。當分區(qū)中出現(xiàn)許多事務并且要保證所有分區(qū)中的數(shù)據(jù)記錄的唯一性時采用全局索引。 1. 局部索引分區(qū)的建立:create index idx_t on AAA(id) 2. 全局索引建立時global 子句允許指定索引的范圍值,這個范圍值為索引字段的范圍值:create index idx_t on AAA(id) 當然也可以不指定索引分區(qū)名直接對整個表建立索引: create index idx_t on AAA(id); 本文出自:億恩科技【www.cmtents.com】 |