全面学习分区表及分区索引(15)--修改表分区属性和模板

http://space.itpub.net/7607759/viewspace-324106

 

1、修改表分区默认属性(Modify Default Attributes)

修改表或表中分区的存储参数,对当前表和分区的存储参数没有影响,只有修改过之后,当你下次再添加分区时,在不手工显式指定新分区参数的情况下,新分区默认使用你当前指定的存储参数。

有两种操作方式:

修改表属性,适用于range,list,hash分区形式(注意hash分区只能修改默认表空间参数)。例如:

JSSWEB> alter table t_partition_list modify default attributes tablespace webtbs;

表已更改。

修改分区属性,适用于组合分区,例如:

JSSWEB> alter table t_partition_rl modify default attributes for partition t_r_p2 tablespace webtbs;

表已更改。

2、修改分区当前属性(Modify Partition)

与上不同,该命令修改的不是默认属性,而是分区当前的存储属性,即修改即生效的那种,虽然号称是修改当前分区属性,但实际上也有限制,比如所在表空间它就改不了(如果你想改,可以用move partition,后面会讲到)。

存储属性呢,三思一向没有过多关注(也许是因为从未有过因此导致的惨痛教训),此节跳过,留待有心人自行查询文档:)

3、修改表子分区模板(Set Subpartition Template)

既然是修改子分区模板,自然是只针对复合分区有效。修改分区模式不会改变当前的分区结构,只有当你再增加、合并分区并且未显式指定子分区存储参数时,才会继承新分区模板中的参数。

该命令语法很简单:alter table tbname set subpartition template ....;

下面举个例子:

JSSWEB> select subpartition_name,tablespace_name from user_subpartition_templates

2 where table_name='T_PARTITION_RH';

SUBPARTITION_NAME TABLESPACE_NAME

---------------------------------- ---------------

H1 TBSPART01

H2 TBSPART02

H3 TBSPART03

H4 TBSPART04

JSSWEB> alter table t_partition_rh

2 set subpartition template(

3 subpartition h1 tablespace tbspart01,

4 subpartition h2 tablespace tbspart02,

5 subpartition h3 tablespace tbspart03);

表已更改。

JSSWEB> select subpartition_name,tablespace_name from user_subpartition_templates

2 where table_name='T_PARTITION_RH';

SUBPARTITION_NAME TABLESPACE_NAME

---------------------------------- ---------------

H1 TBSPART01

H2 TBSPART02

H3 TBSPART03

*这里又学到一个数据字典:user_subpartition_templates,用来查询表的分区模板信息。

如果说,想清除某表的分区模板,那就更简单了:

JSSWEB> select subpartition_name,tablespace_name from user_subpartition_templates

2 where table_name='T_PARTITION_RL';

SUBPARTITION_NAME TABLESPACE_NAME

---------------------------------- ---------------

L1 TBSPART01

L2 TBSPART02

L3 TBSPART03

L4 TBSPART04

JSSWEB> alter table t_partition_rl set subpartition template();

表已更改。

JSSWEB> select * from user_subpartition_templates where table_name='T_PARTITION_RL';

未选定行

=====================================

查看前面的连载:

(14)--截断、移动和重命名

(13)--分隔表分区

(12)--修改list表分区

(11)--合并表分区

(10)--交换表分区

(9)--删除表分区

(8)--增加和收缩表分区

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值