帶default分割槽的列表分割槽表的擴充套件

dawn009發表於2014-11-11
若列表分割槽表中已經建立了default分割槽,則不能再增加分割槽。只能先刪除default分割槽,再增加新分割槽。刪除default分割槽前可以用交換分割槽進行備份。
下面是一個小測試:
--1.建立列表分割槽表
SQL> create table testlp(a, b)
  2  partition by list(a)(
  3  partition testlp1 values(0) tablespace tp_p1,
  4  partition testlp2 values(1) tablespace tp_p2,
  5  partition testlp3 values(2) tablespace tp_p3
  6  )
  7  as select mod(rownum, 3), 1 from user_objects;
表已建立。
SQL> select count(*) from testlp;
  COUNT(*)
----------
        94
SQL> select count(*) from testlp partition(testlp1);
  COUNT(*)
----------
        31
SQL> select count(*) from testlp partition(testlp2);
  COUNT(*)
----------
        32
SQL> select count(*) from testlp partition(testlp3);
  COUNT(*)
----------
        31
--2.當插入的資料不在分割槽鍵值之內,則無法插入
SQL> insert into testlp values(3,3);
insert into testlp values(3,3)
            *
ERROR 位於第 1 行:
ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
--3.可以增加一個default分割槽,來儲存列表以外的資料。
SQL> alter table testlp add partition testlp4 values(default) tablespace tp_p3;
表已更改。
SQL> insert into testlp values(3,3);
已建立 1 行。
SQL> commit;
提交完成。
SQL> select count(*) from testlp partition(testlp4);
  COUNT(*)
----------
         1
--4.由於存在default分割槽,不能再增加新的分割槽
SQL> alter table testlp add partition testlp4 values(3) tablespace tp_p3;
alter table testlp add partition testlp4 values(3) tablespace tp_p3
            *
ERROR 位於第 1 行:
ORA-14323: 在 DEFAULT 分割槽已存在時無法新增分割槽
--5.那麼,我們可以把default分割槽資料進行備份,然後drop掉,來增加新的分割槽。
--5.1建立表testlp_temp儲存default分割槽資料,並透過交換分割槽儲存資料。
SQL> create table testlp_temp as select * from testlp where 1 = 0;
表已建立。
SQL> alter table testlp exchange partition testlp4 with table testlp_temp;
表已更改。
SQL> select count(*) from testlp partition(testlp4);
  COUNT(*)
----------
         0
--5.2drop掉default分割槽
SQL> alter table testlp drop partition testlp4;
表已更改。
--5.3此時可以增加新的分割槽了
SQL> alter table testlp add partition testlp4 values(3) tablespace tp_p3;
表已更改。
--5.4我們把default分割槽也增加上
SQL> alter table testlp add partition testlp5 values(default) tablespace tp_p3;
表已更改。
--5.5此時把備份表testlp_temp中的資料透過交換分割槽匯入分割槽testlp4
SQL> alter table testlp exchange partition testlp4 with table testlp_temp;
表已更改。
SQL> select count(*) from testlp partition(testlp4);
  COUNT(*)
----------
         1
--------------------oracle range分割槽表增加分割槽
oracle range分割槽表增加分割槽
 
這塊要分兩種情況進行試驗,1.沒有maxvalue分割槽。2.有maxvalue分割槽。
 
下面分別試驗之:
   
A.沒有maxvalue的range分割槽表增加分割槽。
 
1.建立分割槽表:
 
SQL> CREATE TABLE t_range_part (ID NUMBER)
 
  2  PARTITION BY RANGE(ID)
 
  3  (
 
  4     PARTITION t_range_1 VALUES LESS THAN (10),
 
  5     PARTITION t_range_2 VALUES LESS THAN (20),
 
  6     PARTITION t_range_3 VALUES LESS THAN (30)
 
  7  );
 
Table created
   
2.檢視分割槽表資訊:
 
SQL> select table_name,partition_name,high_value from dba_tab_partitions where table_name='T_RANGE_PART';
 
TABLE_NAME                     PARTITION_NAME                 HIGH_VALUE
 
------------------------------ ------------------------------ --------------------------------------------------------------------------------
 
T_RANGE_PART                   T_RANGE_1                      10
 
T_RANGE_PART                   T_RANGE_2                      20
 
T_RANGE_PART                   T_RANGE_3                      30
 
3.新增分割槽:
 
SQL> alter table t_range_part add partition t_range_4 values less than (40);
 
Table altered
 
4.再次檢視分割槽表資訊:
 
SQL> select table_name,partition_name,high_value from dba_tab_partitions where table_name='T_RANGE_PART';
 
TABLE_NAME                     PARTITION_NAME                 HIGH_VALUE
 
------------------------------ ------------------------------ --------------------------------------------------------------------------------
 
T_RANGE_PART                   T_RANGE_1                      10
 
T_RANGE_PART                   T_RANGE_2                      20
 
T_RANGE_PART                   T_RANGE_3                      30
 
T_RANGE_PART                   T_RANGE_4                      40
 
由以上結果可以看出,分割槽新增成功!
 
B.有maxvalue分割槽的分割槽表增加分割槽。
 
1.建立分割槽表:
 
SQL> CREATE TABLE t_range_part (ID NUMBER)
 
  2  PARTITION BY RANGE(ID)
 
  3  (
 
  4     PARTITION t_range_1 VALUES LESS THAN (10),
 
  5     PARTITION t_range_2 VALUES LESS THAN (20),
 
  6     PARTITION t_range_3 VALUES LESS THAN (30),
 
  7     PARTITION t_range_max VALUES LESS THAN (MAXVALUE)
 
  8  );
 
Table created
 
2.檢視分割槽表資訊:
 
SQL> select table_name,partition_name,high_value from dba_tab_partitions where table_name='T_RANGE_PART';
 
TABLE_NAME                     PARTITION_NAME                 HIGH_VALUE
 
------------------------------ ------------------------------ --------------------------------------------------------------------------------
 
T_RANGE_PART                   T_RANGE_1                      10
 
T_RANGE_PART                   T_RANGE_2                      20
 
T_RANGE_PART                   T_RANGE_3                      30
 
T_RANGE_PART                   T_RANGE_MAX                    MAXVALUE
 
3.新增分割槽:
 
注意,有了maxvalue,就不能直接add partition,而是需要max分割槽split。下面分別試驗:
 
SQL> alter table t_range_part add partition t_range_4 values less than (40);
 
alter table t_range_part add partition t_range_4 values less than (40)
 
ORA-14074: 分割槽界限必須調整為高於最後一個分割槽界限
 
SQL> alter table t_range_part split partition t_range_max at (40) into (partition t_range_4,partition t_range_max);
 
Table altered
   
4.檢視分割槽表資訊:
 
SQL> select table_name,partition_name,high_value from dba_tab_partitions where table_name='T_RANGE_PART';
 
TABLE_NAME                     PARTITION_NAME                 HIGH_VALUE
 
------------------------------ ------------------------------ --------------------------------------------------------------------------------
 
T_RANGE_PART                   T_RANGE_1                      10
 
T_RANGE_PART                   T_RANGE_2                      20
 
T_RANGE_PART                   T_RANGE_3                      30
 
T_RANGE_PART                   T_RANGE_4                      40
 
T_RANGE_PART                   T_RANGE_MAX                    MAXVALUE
 
結果看出,新增分割槽成功。
 
對於有maxvalue分割槽的分割槽表來說,其實切割最後一個分割槽。
 
--EOF

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29119536/viewspace-1328202/,如需轉載,請註明出處,否則將追究法律責任。

相關文章