首页
登录 | 注册

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

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索引都会失效,需要重新编译。

查看前面的连载:

(7)--怎样管理

(6)--创建range-list组合分区

(5)--创建range-hash组合分区(1)

(4)--创建list分区

(3)--创建hash分区

(2)--创建range分区

(1)--前言



相关文章

  • 博客文章除注明转载外,均为原创.转载请注明出处. 本文链接地址: Oracle普通索引是一种B树结构,在数据查询方面有很高的效率.但是有些时候需要重建索引. 1.什么时候需要重建索引 (1)索引失效,比如ORA-01502错误; (2)索引 ...
  • Oracle sysaux表空间使用过大处理-2
    博客文章除注明转载外,均为原创.转载请注明出处. 接上文(Oracle sysaux表空间使用过大处理-1http://blog.chinaunix.net/uid-31396856-id-5819732.html)介绍另一种处理方法: 基 ...
  • 转载:http://xiaozpjava.iteye.com/blog/1341397 sqlcode sqlstate 说明 000 00000 SQL语句成功完成 01xxx SQL语句成功完成,但是有警告 +012 01545 未限定 ...
  • java处理高并发高负载类网站中数据库的设计方法(java教程,java处理大量数据,java高负载数据)  一:高并发高负载类网站关注点之数据库  没错,首先是数据库,这是大多数应用所面临的首个SPOF.尤其是Web2.0的应用,数据库的 ...
  • MapReduce默认输出是在单个reduce中以key排序的,多个reduce输出之间是不排序的, 所谓全排序,就是指多个reduce之间的输出是有序的. 实现全排序有三种方法: 1.  使用一个reduce进行输出 MapReduce ...
  • 如果不是阿里云的分布式数据库 DRDS 那种多机器集群方案的话: 先考虑表分区 :然后考虑分表 :然后考虑分库. 这个题目是我所经历过的,我做的是GPS应用,早期版本就是选用的关系型数据库Sql Server.当时我选取的方案就是第一种:表 ...

2020 unjeep.com webmaster#unjeep.com
12 q. 0.014 s.
京ICP备10005923号