若列表分割槽表中已經建立了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;
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
----------
94
SQL> select count(*) from testlp partition(testlp1);
COUNT(*)
----------
31
----------
31
SQL> select count(*) from testlp partition(testlp2);
COUNT(*)
----------
32
----------
32
SQL> select count(*) from testlp partition(testlp3);
COUNT(*)
----------
31
----------
31
--2.當插入的資料不在分割槽鍵值之內,則無法插入
SQL> insert into testlp values(3,3);
insert into testlp values(3,3)
*
ERROR 位於第 1 行:
ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
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> 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
----------
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 分割槽已存在時無法新增分割槽
alter table testlp add partition testlp4 values(3) tablespace tp_p3
*
ERROR 位於第 1 行:
ORA-14323: 在 DEFAULT 分割槽已存在時無法新增分割槽
--5.那麼,我們可以把default分割槽資料進行備份,然後drop掉,來增加新的分割槽。
--5.1建立表testlp_temp儲存default分割槽資料,並透過交換分割槽儲存資料。
--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
----------
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分割槽表增加分割槽
----------
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