WEB开发网
开发学院数据库Oracle 全面学习Oracle分区表及分区索引(7)-增加和收缩表... 阅读

全面学习Oracle分区表及分区索引(7)-增加和收缩表分区

 2008-05-27 12:41:46 来源:WEB开发网   
核心提示:1、增加表分区(add partition)增加表分区适应于所有的分区形式,其语法是alter table tbname add partition .....但是,全面学习Oracle分区表及分区索引(7)-增加和收缩表分区,需要注意对于像list,range这种存在范围值的分区,所要增加的分区值必须要大于当前分区中

1、增加表分区(add partition)

增加表分区适应于所有的分区形式,其语法是alter table tbname add partition .....

但是,需要注意对于像list,range这种存在范围值的分区,所要增加的分区值必须要大于当前分区中的最大值(如果当前存在maxvalue或default的分区,add partition会报错,这种情况只能使用split,后面会讲到),hash分区则无此限制。

例如:

  JSSWEB> create table t_partition_range (id number,name varchar2(50))
  2  partition by range(id)(
  3  partition t_range_p1 values less than (10) tablespace tbspart01,
  4  partition t_range_p2 values less than (20) tablespace tbspart02,
  5  partition t_range_p3 values less than (30) tablespace tbspart03
  6  );
  
表已创建。
  
JSSWEB> alter table t_partition_range
  2 add partition t_range_p4 values less than(40);
  
表已更改。

Hash和list的语法与上类似,这里不再举例。

注意:

1、对于hash分区,当你执行add partition操作的时候,oracle会自动选择一个分区,并重新分配部分记录到新建的分区,这也意味着有可能带来一些IO操作。

2、执行alter table时未指定update indexes子句:

如果是range/list分区,其local索引和global索引不会受影响;

如果是hash分区,新加分区及有数据移动的分区的local索引和glocal索引会被置为unuseable,需要重新编译。

3、复合分区完全适用上述所述规则。

2、收缩表分区(coalesce partitions)

Coalesce partition是个很有意思的分区功能,仅能被应用于hash分区或复合分区的hash子分区,执行之后,会自动收缩当前的表分区,比如某表当前有5个hash分区,执行alter table tbname coalesce partitions后就变成4个,再执行一次就变成3个,再执行一次就变2个,再执行一次就...........就报错了:),对于已分区的表至少要有一个分区存在的嘛!

例如:

  JSSWEB> select table_name,partition_name from user_tab_partitions
  2  where table_name='T_PARTITION_HASH';
  
TABLE_NAME           PARTITION_NAME
  ------------------------------ ------------------------------
  T_PARTITION_HASH        T_HASH_P2
  T_PARTITION_HASH        T_HASH_P3
  T_PARTITION_HASH        T_HASH_P4
  T_PARTITION_HASH        T_HASH_P5
  T_PARTITION_HASH        T_HASH_P1
  
JSSWEB> alter table t_partition_hash coalesce partition;
  
表已更改。
  
JSSWEB> select table_name,partition_name from user_tab_partitions
  2  where table_name='T_PARTITION_HASH';
  
TABLE_NAME           PARTITION_NAME
  ------------------------------ ------------------------------
  T_PARTITION_HASH        T_HASH_P2
  T_PARTITION_HASH        T_HASH_P3
  T_PARTITION_HASH        T_HASH_P4
  T_PARTITION_HASH        T_HASH_P1

注意,收缩的只是分区,并不会影响到数据,但是视被收缩分区中数据的多少,收缩表分区也会涉及到IO操作。

另外如果你在执行该语句时没有指定update indexes子句,收缩过程中有数据改动的分区其local索引和glocal索引都会失效,需要重新编译。

Tags:全面 学习 Oracle

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接