地市分站
用户名
密  码
您现在的位置是:树人网首页 / 计算机等级考试 / oracle认证 / 文章浏览
如何将Oracle数据库的普通表转换成分区表(3)
文章来源:来源网络 发表时间:2008-05-22 点击次数
 方法二:使用交换分区的方法

  步骤:

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

  表已创建。

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

  已创建6264行。

  SQL> COMMIT;

  提交完成。

   

  SQL> CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME)

  2 (PARTITION P1 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')),

  3 PARTITION P2 VALUES LESS THAN (MAXVALUE));

  表已创建。

  SQL> ALTER TABLE T_NEW EXCHANGE PARTITION P1 WITH TABLE T;

  表已更改。

  SQL> RENAME T TO T_OLD;

  表已重命名。

  SQL> RENAME T_NEW TO T;

  表已重命名。

  SQL> SELECT COUNT(*) FROM T;

  COUNT(*)

  ----------

  6264

  优点:

  只是对数据字典中分区和表的定义进行了修改,没有数据的修改或复制,效率最高。如果对数据在分区中的分布没有进一步要求的话,实现比较简单。在执行完RENAME操作后,可以检查T_OLD中是否存在数据,如果存在的话,直接将这些数据插入到T中,可以保证对T插入的操作不会丢失。

  不足:

  仍然存在一致性问题,交换分区之后RENAME T_NEW TO T之前,查询、更新和删除会出现错误或访问不到数据。如果要求数据分布到多个分区中,则需要进行分区的SPLIT操作,会增加操作的复杂度,效率也会降低。

  适用于包含大数据量的表转到分区表中的一个分区的操作。应尽量在闲时进行操作。

   

  方法三:Oracle9i以上版本,利用在线重定义功能

  步骤:

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

  表已创建。

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

  已创建6264行。

  SQL> COMMIT;

  提交完成。

  SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(USER’, 'T', DBMS_REDEFINITION.CONS_USE_PK);

  PL/SQL 过程已成功完成。

  SQL> CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME)

  2 (PARTITION P1 VALUES LESS THAN (TO_DATE('2004-7-1', 'YYYY-MM-DD')),

  3 PARTITION P2 VALUES LESS THAN (TO_DATE('2005-1-1', 'YYYY-MM-DD')),

  4 PARTITION P3 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')),

  5 PARTITION P4 VALUES LESS THAN (MAXVALUE));

  表已创建。



1 2 3 4

责任编辑:qwer19871212

相关文章
公告栏

“蓝焰杯”第二届河南教育十大新闻人物火热评选中!!

点击参加评选,为你心目中的新闻人物投上一票>>>>
频道内容精选
[计算机考试]程序员必考的知识点
论坛/博客精选