全部產品
Search
文件中心

PolarDB:ALTER TABLE...MERGE SUBPARTITION

更新時間:Jul 06, 2024

使用ALTER TABLE...MERGE SUBPARTITION命令可以將兩個子分區合并為一個新的子分區,新的子分區包含原有兩個子分區的所有內容。

說明
  • 您必須是表的所有者或擁有表的系統管理權限才能執行該語句。
  • 該SQL命令僅支援在LIST分區表和RANGE分區表中使用,不支援在HASH分區表中使用。
  • 如果表中已經建立索引,將在新分區中也建立該索引。

文法

ALTER TABLE table_name MERGE SUBPARTITIONS
        partition_name , partition_name 
        INTO SUBPARTITION  new_part [TABLESPACE tablespace_name] ;

參數

參數說明
table_name分區表的名稱,可指定Schema。
partition_name需要合并的兩個子分區名稱,以英文逗號(,)分隔。
new_part合并後新子分區的名稱。

分區名稱在所有分區和子分區中必須唯一。

tablespace_name指定新子分區將駐留的資料表空間。

如果未指定資料表空間,則新子分區將建立在預設資料表空間中。

樣本

建立一個名為sales的分區表,並在表中插入測試資料,樣本如下:

CREATE TABLE sales
(
  dept_no     number,   
  part_no     varchar2,
  country     varchar2(20),
  date        date,
  amount      number
)
PARTITION BY LIST(country)
  SUBPARTITION BY RANGE(date)
(
  PARTITION europe VALUES('FRANCE', 'ITALY')
    (
      SUBPARTITION europe_2011 
        VALUES LESS THAN('2012-Jan-01'),
      SUBPARTITION europe_2012 
        VALUES LESS THAN('2013-Jan-01')
    ),
  PARTITION asia VALUES('INDIA', 'PAKISTAN')
    (
      SUBPARTITION asia_2011 
        VALUES LESS THAN('2012-Jan-01'),
      SUBPARTITION asia_2012 
        VALUES LESS THAN('2013-Jan-01')
    ),
  PARTITION americas VALUES('US', 'CANADA')
    (
      SUBPARTITION americas_2011 
        VALUES LESS THAN('2012-Jan-01'),
      SUBPARTITION americas_2012 
        VALUES LESS THAN('2013-Jan-01')
    )
);
SELECT partition_name, subpartition_name, high_value FROM ALL_TAB_SUBPARTITIONS where table_name = 'SALES';
INSERT INTO sales VALUES
  (10, '4519b', 'FRANCE', '17-Jan-2012', '45000'),
  (20, '3788a', 'INDIA', '01-Mar-2012', '75000'),
  (40, '9519b', 'US', '12-Apr-2012', '145000'),
  (20, '3788a', 'PAKISTAN', '04-Jun-2012', '37500'),
  (40, '4577b', 'US', '11-Nov-2012', '25000'),
  (30, '7588b', 'CANADA', '14-Dec-2012', '50000'),
  (30, '9519b', 'CANADA', '01-Feb-2012', '75000'),
  (30, '4519b', 'CANADA', '08-Apr-2012', '120000'),
  (40, '3788a', 'US', '12-May-2012', '4950'),
  (10, '9519b', 'ITALY', '07-Jul-2012', '15000'),
  (10, '9519a', 'FRANCE', '18-Aug-2012', '650000'),
  (10, '9519b', 'FRANCE', '18-Aug-2012', '650000'),
  (20, '3788b', 'INDIA', '21-Sept-2012', '5090'),
  (40, '4788a', 'US', '23-Sept-2012', '4950'),
  (40, '4788b', 'US', '09-Oct-2012', '15000'),
  (20, '4519a', 'INDIA', '18-Oct-2012', '650000'),
  (20, '4519b', 'INDIA', '2-Dec-2012', '5090');
SELECT tableoid::regclass, * FROM sales;

americas_2012子分區拆分成americas_p1_2012americas_p2_2012兩個子分區,樣本如下:

ALTER TABLE sales 
  SPLIT SUBPARTITION americas_2012 
  AT('2012-Jun-01')
  INTO
  (
    SUBPARTITION americas_p1_2012, 
    SUBPARTITION americas_p2_2012
  );

americas_p1_2012子分區和americas_p2_2012子分區合并到一個新子分區new_americas_2012,樣本如下:

ALTER TABLE sales 
  MERGE SUBPARTITIONS americas_p1_2012 ,americas_p2_2012
  INTO  SUBPARTITION new_americas_2012;