ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 11g普通range分区和interval分区转化

11g普通range分区和interval分区转化

原创 Linux操作系统 作者:安佰胜 时间:2013-10-24 14:08:12 0 删除 编辑

普通range分区和interval分区转化

---------------------------------------

--创建测试表,表为普通range分区
drop table an_test;

create table an_test(
day DATE
)
partition by range(day) (
partition p1 values less than(to_date('2013-01-01','yyyy-mm-dd'))
);


--将表转化为interval分区表
ALTER TABLE an_test SET INTERVAL (numtoyminterval(1,'year'));

--插入测试数据,并检查数据
SQL> insert into an_test select sysdate+365 from dual;

1 row created.

SQL> commit;

Commit complete.

SQL> select * from an_test;

DAY
---------
24-OCT-14

--查看分区,分区sys_p61就是自动创建的分区
SQL> select partition_name from dba_tab_partitions where table_name='AN_TEST';

PARTITION_NAME
------------------------------
P1
SYS_P61


----------------------


--反向操作,即将interval分区表转化为普通range分区

ALTER TABLE an_test SET INTERVAL ();

Table altered.

--手动减价分区p2验证
SQL> alter table an_test add partition p2  values less than (to_date('2016-01-01','yyyy-mm-dd'));

Table altered.

SQL> select partition_name from dba_tab_partitions where table_name='AN_TEST';

PARTITION_NAME
------------------------------
P1
P2
SYS_P61

另:反向操作后可以出现在数据中断、补建分区或者调整分区步长的情景
使用类似ALTER TABLE an_test SET INTERVAL (numtoyminterval(1,'year'));命令调整interval步长后,后面的分区按照新的interval生成

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

上一篇: get_plan_by_sqlid
下一篇: 12c安装
请登录后发表评论 登录
全部评论

注册时间:2009-08-26

  • 博文量
    215
  • 访问量
    612731