Exchange partition提供了一种方式,让你在表与表或分区与分区之间迁

移数据,注意不是将表转换成分区或非分区的形式,而仅只是迁移表中数

据(互相迁移),由于其号称是采用了更改数据字典的方式,因此效率最高(

几乎不涉及io操作)。Exchange partition适用于所有分区格式,你可以将

数据从分区表迁移到非分区表,也可以从非分区表迁移至分区表,或者从

hash partition到range partition诸如此类吧。

  其语法很简单:alter table tbname1 exchange

partition/subpartition ptname with table tbname2;

注意:在将未分区表的数据迁移到分区表中时,可能出现ora-14099的错误,虽然可以用without validation去解决,但是此时进入分区表的数据可能不符合分区规则。所以without validation一定要慎用。

  l 涉及交换的两表之间表结构必须一致,除非附加with validation子

句;

  l 如果是从非分区表向分区表做交换,非分区表中的数据必须符合分

区表中指定分区的规则,除非附加without validation子句;

  l 如果从分区表向分区表做交换,被交换的分区的数据必须符合分区

规则,除非附加without validation子句;

  l Global索引或涉及到数据改动了的global索引分区会被置为

unusable,除非附加update indexes子句。

  提示:

  一旦附加了without validation子句,则表示不再验证数据有效性,

因此指定该子句时务必慎重。