oracle根据多字段创建分区表
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle根据多字段创建分区表相关的知识,希望对你有一定的参考价值。
参考技术A 最近有业务场景需要用多个字段做分区表,数据量比较大,保存时间也较长,经过学习与实践,算是基本完成,以下内容为实践样例:---建表语句
create table t_table
(
areacode varchar2(10),
appdate date,
text varchar(10)
)
partition by range(appdate)--根据字段 appdate 创建主分区
interval(numtoyminterval(1,'MONTH')) --主分区按 月 自动创建分区
subpartition by list(areacode) --再按 地区 创建子分区
subpartition template( --指定明确的子分区信息
subpartition sub1 values('101'),
subpartition sub2 values('201'),
subpartition sub3 values('301')
)
(
partition mainpartition1 values less than(to_date('2019-04-01','yyyy-mm-dd'))--2019年4月1日前的放入mainpartition1分区,之后的自动分区
)
---模拟写入测试数据
insert into t_table values('101',to_date('2019-03-03','yyyy-mm-dd'),'a');
insert into t_table values('101',to_date('2019-02-03','yyyy-mm-dd'),'a');
insert into t_table values('101',to_date('2019-04-03','yyyy-mm-dd'),'a');
insert into t_table values('201',to_date('2019-03-03','yyyy-mm-dd'),'a');
insert into t_table values('201',to_date('2019-05-03','yyyy-mm-dd'),'a');
insert into t_table values('301',to_date('2019-04-01','yyyy-mm-dd'),'a');
--查询数据
select * from t_table;
--查询主分区数据
select *from t_table partition (mainpartition1);
--查询子分区数据
select *from t_table subpartition (mainpartition1_sub1);
--查看自动创建的主分区
select * from user_tab_partitions where table_name='T_TABLE'
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;
报错信息如下
以上是关于oracle根据多字段创建分区表的主要内容,如果未能解决你的问题,请参考以下文章