oracle分区表之交换分区 altertable exchange partition with table

本文深入探讨了Exchangepartition在数据库迁移中的应用,提供了迁移过程中的注意事项,包括交换条件、避免常见错误及确保数据一致性的方法。通过示例展示了如何在不同表结构间高效迁移数据,并强调了使用withoutvalidation时的风险评估。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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子句,则表示不再验证数据有效性,

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

实验:

SQL> CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE);

Table created.

SQL> INSERT INTO T SELECT ROWNUM, CREATED FROM DBA_OBJECTS;

72009 rows created.

Commit complete.


SQL>  CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME) (PARTITION P1 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')),PARTITION P2 VALUES LESS THAN (MAXVALUE));

Table created.

SQL> alter table t_new exchange partition p1 with table t;
alter table t_new exchange partition p1 with table t
                                                   *
ERROR at line 1:
ORA-14099: all rows in table do not qualify for specified partition


SQL> alter table t_new exchange partition p1 with table t without validation;

Table altered.

SQL> select count(*) from t;

  COUNT(*)
----------
         0

SQL> select count(*) from t_new;

  COUNT(*)
----------
     72009

SQL> rename t to t_old;

Table renamed.

SQL>  select count(*) from t;
 select count(*) from t
                      *
ERROR at line 1:
ORA-00942: table or view does not exist


SQL> rename t_new to t;

Table renamed.

SQL>  select count(*) from t;

  COUNT(*)
----------
     72009

SQL>
参考:http://www.cnblogs.com/wuyisky/archive/2011/03/24/1994333.html

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值