全面学习分区表及分区索引(15)--修改表分区属性和模板
1、修改表分区默认属性(Modify Default Attributes)
修改表或表中分区的存储参数,对当前表和分区的存储参数没有影响,只有修改过之后,当你下次再添加分区时,在不手工显式指定新分区参数的情况下,新分区默认使用你当前指定的存储参数。
有两种操作方式:
修改表属性,适用于range,list,hash分区形式(注意hash分区只能修改默认表空间参数)。例如:
SQL> alter table t_part_list modify default attributes tablespace part03;
Table altered
SQL> alter table t_part_list modify default attributes tablespace karl_space;
Table altered
修改分区属性,适用于组合分区,例如:
SQL> alter table t_part_rh modify default attributes for partition t_r_p1 tablespace part03;
Table altered
SQL> alter table t_part_rh modify default attributes for partition t_r_p1 tablespace karl_space ;
Table altered
2、修改表分区当前属性(Modify Partition)
与上不同,该命令修改的不是默认属性,而是分区当前的存储属性,即修改即生效的那种,虽然号称是修改当前分区属性,但实际上也有限制,比如所在表空间它就改不了(如果你想改,可以用move partition,后面会讲到)。
存储属性呢,未多关注,此节跳过。
3、修改表子分区模板(Set Subpartition Template)
既然是修改子分区模板,自然是只针对复合分区有效。修改分区模式不会改变当前的分区结构,只有当你再增加、合并分区并且未显式指定子分区存储参数时,才会继承新分区模板中的参数。
该命令语法很简单:alter table tbname set subpartition template ....;
下面举个例子:
SQL> select subpartition_name,tablespace_name from user_subpartition_templates
2 where table_name='T_PART_RH';
SUBPARTITION_NAME TABLESPACE_NAME
---------------------------------- ------------------------------
SQL>
SQL> alter table T_PART_RH
2 set subpartition template(
3 subpartition l1 tablespace part01,
4 subpartition l2 tablespace part02,
5 subpartition l3 tablespace part03)
6 ;
Table altered
SQL>
SQL> select subpartition_name,tablespace_name from user_subpartition_templates
2 where table_name='T_PART_RH';
SUBPARTITION_NAME TABLESPACE_NAME
---------------------------------- ------------------------------
L1 PART01
L2 PART02
L3 PART03
*这里又学到一个数据字典:user_subpartition_templates,用来查询表的分区模板信息。
如果说,想清除某表的分区模板,那就更简单了:
SQL> alter table t_part_rh set subpartition template(
2 subpartition l1 tablespace part01,
3 subpartition l2 tablespace part02,
4 subpartition l3 tablespace part03);
Table altered
SQL> select * from user_subpartition_templates;
TABLE_NAME SUBPARTITION_NAME SUBPARTITION_POSITION TABLESPACE_NAME HIGH_BOUND
------------------------------ ---------------------------------- --------------------- ------------------------------ --------------------------------------------------------------------------------
T_PART_RH L1 1 PART01
T_PART_RH L2 2 PART02
T_PART_RH L3 3 PART03
6 rows selected
SQL> alter table t_part_rh set subpartition template();
Table altered
SQL> select * from user_subpartition_templates;
TABLE_NAME SUBPARTITION_NAME SUBPARTITION_POSITION TABLESPACE_NAME HIGH_BOUND
------------------------------ ---------------------------------- --------------------- ------------------------------ --------------------------------------------------------------------------------
1、修改表分区默认属性(Modify Default Attributes)
修改表或表中分区的存储参数,对当前表和分区的存储参数没有影响,只有修改过之后,当你下次再添加分区时,在不手工显式指定新分区参数的情况下,新分区默认使用你当前指定的存储参数。
有两种操作方式:
修改表属性,适用于range,list,hash分区形式(注意hash分区只能修改默认表空间参数)。例如:
SQL> alter table t_part_list modify default attributes tablespace part03;
Table altered
SQL> alter table t_part_list modify default attributes tablespace karl_space;
Table altered
修改分区属性,适用于组合分区,例如:
SQL> alter table t_part_rh modify default attributes for partition t_r_p1 tablespace part03;
Table altered
SQL> alter table t_part_rh modify default attributes for partition t_r_p1 tablespace karl_space ;
Table altered
2、修改表分区当前属性(Modify Partition)
与上不同,该命令修改的不是默认属性,而是分区当前的存储属性,即修改即生效的那种,虽然号称是修改当前分区属性,但实际上也有限制,比如所在表空间它就改不了(如果你想改,可以用move partition,后面会讲到)。
存储属性呢,未多关注,此节跳过。
3、修改表子分区模板(Set Subpartition Template)
既然是修改子分区模板,自然是只针对复合分区有效。修改分区模式不会改变当前的分区结构,只有当你再增加、合并分区并且未显式指定子分区存储参数时,才会继承新分区模板中的参数。
该命令语法很简单:alter table tbname set subpartition template ....;
下面举个例子:
SQL> select subpartition_name,tablespace_name from user_subpartition_templates
2 where table_name='T_PART_RH';
SUBPARTITION_NAME TABLESPACE_NAME
---------------------------------- ------------------------------
SQL>
SQL> alter table T_PART_RH
2 set subpartition template(
3 subpartition l1 tablespace part01,
4 subpartition l2 tablespace part02,
5 subpartition l3 tablespace part03)
6 ;
Table altered
SQL>
SQL> select subpartition_name,tablespace_name from user_subpartition_templates
2 where table_name='T_PART_RH';
SUBPARTITION_NAME TABLESPACE_NAME
---------------------------------- ------------------------------
L1 PART01
L2 PART02
L3 PART03
*这里又学到一个数据字典:user_subpartition_templates,用来查询表的分区模板信息。
如果说,想清除某表的分区模板,那就更简单了:
SQL> alter table t_part_rh set subpartition template(
2 subpartition l1 tablespace part01,
3 subpartition l2 tablespace part02,
4 subpartition l3 tablespace part03);
Table altered
SQL> select * from user_subpartition_templates;
TABLE_NAME SUBPARTITION_NAME SUBPARTITION_POSITION TABLESPACE_NAME HIGH_BOUND
------------------------------ ---------------------------------- --------------------- ------------------------------ --------------------------------------------------------------------------------
T_PART_RH L1 1 PART01
T_PART_RH L2 2 PART02
T_PART_RH L3 3 PART03
6 rows selected
SQL> alter table t_part_rh set subpartition template();
Table altered
SQL> select * from user_subpartition_templates;
TABLE_NAME SUBPARTITION_NAME SUBPARTITION_POSITION TABLESPACE_NAME HIGH_BOUND
------------------------------ ---------------------------------- --------------------- ------------------------------ --------------------------------------------------------------------------------