利用dbms_redefinition实现普通heap表和分区表的转化

客户想把一个重要的普通表转化为分区表,简单的测试了一下9i就引入的dbms_redefinition[@more@]

SQL> create table t2(id int primary key , name varchar2(10) , time date);

表已创建。
SQL> insert into t2 values(1,'a',to_date('2009/09/02 10:12:21','yyyy/mm/dd hh24:
mi:ss'));

已创建 1 行。

SQL> insert into t2 values(2,'b',to_date('2009/10/10 10:12:21','yyyy/mm/dd hh24:
mi:ss'));

已创建 1 行。

SQL> insert into t2 values(3,'c',to_date('2009/11/20 15:12:36','yyyy/mm/dd hh24:
mi:ss'));

已创建 1 行。

SQL> insert into t2 values(100,'d',to_date('2010/11/20 15:12:36','yyyy/mm/dd hh2
4:mi:ss'));

已创建 1 行。

SQL> commit;

提交完成。

SQL> select * from t2;

ID NAME TIME
---------- ---------- --------------
1 a 02-9月 -09
2 b 10-10月-09
3 c 20-11月-09
100 d 20-11月-10
SQL>exec DBMS_REDEFINITION.can_REDEF_TABLE('SYS','T2',1);
BEGIN DBMS_REDEFINITION.can_REDEF_TABLE('SYS','T2',1); END;

*
第 1 行出现错误:
ORA-12087: 在 "SYS" 拥有的表上不允许联机重新定义
ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 137
ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 1478
ORA-06512: 在 line 1
--sys用户下的表不允许联机重定义
SQL> create table test.t2 as select * from t2;

表已创建。

SQL> connect test/test@test
已连接。
--下面测试是把普通heap 表转换为分区表,使用primary key重定义也可以使用rowid重定义
SQL> alter table t2 add constraint pk_t2 primary key (id);

表已更改。
--验证是否可以进行REDEFINITION,如果不能则会给出原因
SQL> exec DBMS_REDEFINITION.can_REDEF_TABLE('TEST','T2',1);

PL/SQL 过程已成功完成。
--创建中间转换需要的临时分区表
SQL> create table t2_p_tmp(id int , name varchar2(10),time date)
2 partition by range(time)(
3 partition t2_p200909 values less than(to_date('2009/10/01','yyyy/mm/dd')),
4 partition t2_p200910 values less than(to_date('2009/11/01','yyyy/mm/dd')),
5 partition t2_p200911 values less than(to_date('2009/12/01','yyyy/mm/dd')),
6 partition t2_p200912 values less than(to_date('2010/12/01','yyyy/mm/dd'))
7 );

表已创建。

SQL>
--开始重定义
SQL> begin
2 dbms_redefinition.start_redef_table('TEST','T2','T2_P_TMP','id id, name nam
e,time time',dbms_redefinition.cons_use_pk);
3 end;
4 /
--同步数据
PL/SQL 过程已成功完成。
SQL> exec dbms_redefinition.sync_interim_table('TEST','T2','T2_P_TMP');

PL/SQL 过程已成功完成。

--结束重定义的过程
SQL> exec dbms_redefinition.finish_redef_table('TEST','T2','T2_P_TMP');

PL/SQL 过程已成功完成。
--删除临时表
SQL> drop table t2_p_tmp;

表已删除。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/19602/viewspace-1028165/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/19602/viewspace-1028165/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值