1.1 创建表
CREATE TABLE t_range_interval
(id number,deal_date date,area_code number,nbr number,contents varchar2(4000))
PARTITION BY RANGE (deal_date)
INTERVAL(NUMTOYMINTERVAL(1, 'MONTH'))
( partition p_201911 values less than (TO_DATE('2019-12-01', 'YYYY-MM-DD')),
partition p_201912 values less than (TO_DATE('2020-01-01', 'YYYY-MM-DD')));
1.2 插入数据
insert into t_range_interval (id,deal_date,area_code,nbr,contents)
select rownum,
sysdate-360+ TRUNC(DBMS_RANDOM.VALUE(0,365)),
ceil(dbms_random.value(591,599)),
ceil(dbms_random.value(18900000001,18999999999)),
rpad('*',400,'*')
from dual
connect by rownum <= 10000;
select MIN(deal_date),MAX(deal_date) from t_range_interval;

1.3 查看自动生成的分区
select segment_name,
partition_name,
segment_type,
bytes ,
tablespace_name
from user_segments
where segment_name ='T_RANGE_INTERVAL';

1.4 验证数据分布
select
(select count(*) from T_RANGE_INTERVAL partition(SYS_P2662_2673)) SYS_P2662_2673,
(select count(*) from T_RANGE_INTERVAL partition(SYS_P2662_2671)) SYS_P2662_2671,
(select count(*) from T_RANGE_INTERVAL partition(SYS_P2662_2669)) SYS_P2662_2669,
(select count(*) from T_RANGE_INTERVAL partition(SYS_P2662_2667)) SYS_P2662_2667,
(select count(*) from T_RANGE_INTERVAL partition(SYS_P2662_2665)) SYS_P2662_2665,
(select count(*) from T_RANGE_INTERVAL partition(P_201912)) P_201912,
(select count(*) from T_RANGE_INTERVAL partition(P_201911)) P_201911
from dual

select MIN(deal_date),MAX(deal_date),'SYS_P2662_2673' from T_RANGE_INTERVAL partition(SYS_P2662_2673)
UNION
select MIN(deal_date),MAX(deal_date),'SYS_P2662_2671' from T_RANGE_INTERVAL partition(SYS_P2662_2671)
UNION
select MIN(deal_date),MAX(deal_date),'SYS_P2662_2669' from T_RANGE_INTERVAL partition(SYS_P2662_2669)
UNION
select MIN(deal_date),MAX(deal_date),'SYS_P2662_2667' from T_RANGE_INTERVAL partition(SYS_P2662_2667)
UNION
select MIN(deal_date),MAX(deal_date),'SYS_P2662_2665' from T_RANGE_INTERVAL partition(SYS_P2662_2665)
UNION
select MIN(deal_date),MAX(deal_date),'P_201912' from T_RANGE_INTERVAL partition(P_201912)
UNION
select MIN(deal_date),MAX(deal_date),'P_201911' from T_RANGE_INTERVAL partition(P_201911)

最后修改时间:2020-06-03 17:32:02
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




