本篇文章為大家展示了如何進行合并分區coalesce partition,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
合并分區(coalesce partition):合并分區是用來操作HASH分區表和hash全局索引的。他會重新分配刪除的分區的數據到你現有的分區中。
限制:操作HASH分區表和hash全局索引,如果對LIST/RANGE分區表進行合并報錯ORA-14259: 表未被散列方法分區
全局索引只有RANGE和HASH才有,并且RANGE不能使用合并,同時也不能對range分區進行添加分區報錯ORA-14640: 添加/合并索引分區操作只對散列分區的全局索引有效,
而且建立全局RANGE分區必須帶有MAXVALUE屬性,并且是不行刪除的MAXVALUE分區,如果刪除報錯ORA-14078: 您不能刪除 GLOBAL 索引的最高分區。
我們這里討論對索引的影響,包括全局索引,本地索引和普通索引。
使用腳本:
drop table t_pe_h;
CREATE TABLE t_pe_h (i NUMBER, j NUMBER , f number,k varchar2(20))
PARTITION BY hash(j)
(PARTITION p1 ,
PARTITION p2,
partition p4,
partition p3);
create index t_pe_h_n on t_pe_h(i);
create index t_pe_h_l on t_pe_h(j) local;
create index t_pe_h_g on t_pe_h(f)
GLOBAL PARTITION BY range(f)
(PARTITION p1 VALUES less than (10),
PARTITION p2 VALUES less than (20),
PARTITION p3 VALUES less than (maxvalue ));
insert into t_pe_h
values(2,5,5,'A');
insert into t_pe_h
values(1,15,10,'B');
insert into t_pe_h
values(3,25,40,'C');
insert into t_pe_h
values(2,65,30,'A');
insert into t_pe_h
values(1,75,20,'B');
insert into t_pe_h
values(3,85,50,'C');
select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_l';
select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_g';
select INDEX_NAME ,STATUS from dba_indexes where lower(index_name)='t_pe_h_n';
然后查看索引狀態
SQL> ALTER TABLE t_pe_h
2 COALESCE PARTITION;
Table altered
SQL>
SQL> select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_l';
INDEX_NAME STATUS PARTITION_NAME
------------------------------ -------- ------------------------------
T_PE_H_L USABLE P4
T_PE_H_L UNUSABLE P2
T_PE_H_L USABLE P1
SQL> select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_g';
INDEX_NAME STATUS PARTITION_NAME
------------------------------ -------- ------------------------------
T_PE_H_G UNUSABLE P3
T_PE_H_G UNUSABLE P2
T_PE_H_G UNUSABLE P1
SQL> select INDEX_NAME ,STATUS from dba_indexes where lower(index_name)='t_pe_h_n';
INDEX_NAME STATUS
------------------------------ --------
T_PE_H_N UNUSABLE
可以發現都失效了,明顯的合并分區自動把P2 ,P3合并為P2了,并且起本地索引相關的P2分區也失效了,因為底層的表的ROWID改變了。
普通索引和全局索引均失效。
然后我們試試UPDATE INDEXES
SQL> ALTER TABLE t_pe_h
2 COALESCE PARTITION update indexes;
Table altered
SQL>
SQL> select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_l';
INDEX_NAME STATUS PARTITION_NAME
------------------------------ -------- ------------------------------
T_PE_H_L USABLE P4
T_PE_H_L USABLE P2
T_PE_H_L USABLE P1
SQL> select INDEX_NAME ,STATUS,a.partition_name from dba_ind_partitions a where lower(index_name)='t_pe_h_g';
INDEX_NAME STATUS PARTITION_NAME
------------------------------ -------- ------------------------------
T_PE_H_G USABLE P3
T_PE_H_G USABLE P2
T_PE_H_G USABLE P1
SQL> select INDEX_NAME ,STATUS from dba_indexes where lower(index_name)='t_pe_h_n';
INDEX_NAME STATUS
------------------------------ --------
T_PE_H_N VALID
可以看到均有效,沒有問題。另外你還可以使用合并分區來合并全局HASH的索引,如下:
ALTER INDEX hgidx COALESCE PARTITION;(對hash全局分區索引有效)
上述內容就是如何進行合并分區coalesce partition,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。