ORACLE普通表转换成自动分区表

1、先创建一张和普通表一样的分区表(表的字段太多了,这字段是经过筛选用来测试)

创建分区表语法关键定义:

根据年: INTERVAL(NUMTOYMINTERVAL(1,'YEAR'))
根据月: INTERVAL(NUMTOYMINTERVAL(1,'MONTH'))
根据天: INTERVAL(NUMTODSINTERVAL(1,'DAY'))
根据时分秒: NUMTODSINTERVAL( n, { 'DAY'|'HOUR'|'MINUTE'|'SECOND'})

同时可以通过MAXVALUE来指定最大值,MAXVALUE用实际值代替

--,PARTITION DW_KAD_PRM_DETAILS_PART_MAXVAL values LESS THAN (MAXVALUE)

以上。

先查询出原表最小日期select min(starttime ) from DW_KAD_PRM_DETAILS;

我这边查询出的最小日期是0001/01/01这个特殊值,那么久从这个字段开始,建表语句如下:

create table DW_KAD_PRM_DETAILS_PART
(
  prmcode        VARCHAR2(50),
  prmname        VARCHAR2(1000),
  prmdesc        VARCHAR2(1000),
  starttime      DATE,
  endtime        DATE,
  prmflagname    VARCHAR2(50),
  prmtypecode    VARCHAR2(50),
  prmtypename    VARCHAR2(100),
  modifytime     DATE,
  createtime     DATE default sysdate
)
tablespace BIDEV_DATA
PARTITION BY RANGE (starttime) interval (numtoyminterval(1, 'month'))
STORE IN (BIDEV_DATA)
(
  partition DW_KAD_PRM_DETAILS_PART_SP1 values less than (to_date('0001/01/01','yyyy/mm/dd')) tablespace BIDEV_DATA
  --,PARTITION DW_KAD_PRM_DETAILS_PART_MAXVAL values LESS THAN (to_date('2999/12/31','yyyy/mm/dd'))  这里需要自增长,所以不限上限

);
/*-- Create/Recreate indexes
create index IDX1_DW_KAD_PRM_DETAILS_PART on DW_KAD_PRM_DETAILS_PART (PRMCODE)
  tablespace BIDEV_DATA
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );*/


2、将原表的数据插入

insert into DW_KAD_PRM_DETAILS_PART
select * from bidev.dw_kad_prm_details where STARTTIME<date'2012-01-05';


查看表的效果如下,sys_开头的分区就是数据库自行创建


分区列是不许有空值存在的,如果插入空值则报错ORA-14300

insert into DW_KAD_PRM_DETAILS_PART
select * from bidev.dw_kad_prm_details where STARTTIME is null and rownum<10;

报错信息如下


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值