合併分割槽(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全域性分割槽索引有效)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7728585/viewspace-756884/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 分割槽Partition
- 分割槽partition知識點
- win10怎麼合併分割槽_win10合併分割槽的方法Win10
- mac分割槽合併APFS容器Mac
- Spark學習——分割槽Partition數Spark
- win10u盤分割槽怎麼合併 win10如何把U分割槽合併Win10
- Oracle Partition 分割槽詳細總結Oracle
- 分割槽函式Partition By的基本用法函式
- Kafka分割槽分配策略(Partition Assignment Strategy)Kafka
- 分割槽函式partition by的基本用法【轉載】函式
- Oracle查詢Interval partition分割槽表內資料Oracle
- win10分割槽合併不了的解決方法_win10分割槽合併不了如何處理Win10
- 使用parted建立大分割槽時 mkpart Warning: The resulting partition is not properly
- win10分割槽合併保留資料怎麼操作_win10硬碟合併分割槽並保留檔案詳細步驟Win10硬碟
- MySQL全面瓦解29:使用Partition功能實現水平分割槽MySql
- Oracle分割槽表基礎運維-05組合分割槽Oracle運維
- win10系統OEM分割槽怎麼合併或刪除Win10
- 影片合併分割軟體如何合併影片
- Flink SQL FileSystem Connector 分割槽提交與自定義小檔案合併策略 SQL
- PostgreSQL11preview-索引優化。filter智慧消除、分割槽索引智慧合併SQLView索引優化Filter
- WINDOWS還原系統後原多個分割槽合併為一個分割槽後怎麼進行資料恢復Windows資料恢復
- windows10系統合併分割槽後c盤過大怎麼辦Windows
- WINDOWS還原系統後分割槽合併為一個怎麼恢復Windows
- Partition|Disk Utility 如何分割磁碟
- Linux分割槽方案、分割槽建議Linux
- win10系統下怎麼將D盤合併分割槽到c盤Win10
- 硬碟/行動硬碟分割槽合併失敗資料丟失瞭如何恢復?硬碟
- 7.51 COALESCE
- Laravel Query Builder 複雜查詢案例:子查詢實現分割槽查詢 partition byLaravelUI
- oracle分割槽表和分割槽表exchangeOracle
- PostgreSQL/LightDB 分割槽表之分割槽裁剪SQL
- Linux 分割槽擴容(根分割槽擴容,SWAP 分割槽擴容,掛載新分割槽為目錄)Linux
- shell 檔案合併 去重 分割
- 關於numpy的索引、合併、分割索引
- java快速分割及合併檔案Java
- Oracle分割槽表基礎運維-07增加分割槽(2 HASH分割槽)Oracle運維
- oracle分割槽表和非分割槽表exchangeOracle
- 非分割槽錶轉換成分割槽表
- [oracle] expdp 匯出分割槽表的分割槽Oracle