11g新增的INTERVAL分区使得RANGE分区的新建分区工作大为简化,这个工作将随着数据的插入由Oracle自动完成。
顾名思义INTERVAL分区需要提供一个INTERVAL,而对于字符类型是不存在INTERVAL的,因此只有NUMBER类型和DATE类型支持INTERVAL分区。
其中NUMBER类型的INTERVAL分区很简单,因此这里仅描述相对复杂一点的DATE类型的INTERVAL分区。需要注意这里的DATE是泛指,包括DATE、TIMESTANP、TIMESTAMP WITH ZONE和TIMESTAMP WITH LOCAL ZONE多个日期相关的数据类型。
对于INTERVAL值的限定,有两种方法,一种是通过NUMTOYMINTERVAL或NUMTODSINTERAL函数:
SQL> CREATE TABLE T_PART_INTER_MONTH 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (NUMTOYMINTERVAL(1, 'MONTH')) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-1', 'YYYY-MM'))); 表已创建。 SQL> CREATE TABLE T_PART_INTER_DAY 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (NUMTODSINTERVAL(1, 'DAY')) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-1-1', 'YYYY-MM-DD'))); 表已创建。
复制
另一种等价的方法是直接利用INTERVAL表达式:
SQL> DROP TABLE T_PART_INTER_MONTH PURGE; 表已删除。 SQL> DROP TABLE T_PART_INTER_DAY PURGE; 表已删除。 SQL> CREATE TABLE T_PART_INTER_MONTH 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (INTERVAL '1' MONTH) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-1', 'YYYY-MM'))); 表已创建。 SQL> CREATE TABLE T_PART_INTER_DAY 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (INTERVAL '1' DAY) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-1-1', 'YYYY-MM-DD'))); 表已创建。
复制
无论使用哪种方法,其实都是INTERVAL的方式,这种方式和ADD_MONTHS函数不同,不会自动处理月末的问题,因此以月为单位的INTERVAL不能以超过28日的日期作为最后一个范围分区的上限:
SQL> CREATE TABLE T_PART_TEST 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (INTERVAL '1' MONTH) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-3-29', 'YYYY-MM-DD'))); CREATE TABLE T_PART_TEST * 第 1 行出现错误: ORA-14767: 无法使用现有上限指定此间隔 避免这种错误其实很简单,最简单的是利用28日作为分区上限: SQL> CREATE TABLE T_PART_TEST 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (INTERVAL '1' MONTH) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-3-28', 'YYYY-MM-DD'))); 表已创建。
复制
或者再建立一个最高分区,避免超过28日的日志作为最后一个分区的上限出现:
表已删除。 SQL> CREATE TABLE T_PART_TEST 2 (ID NUMBER, 3 NAME VARCHAR2(30), 4 CREATE_DATE DATE) 5 PARTITION BY RANGE (CREATE_DATE) 6 INTERVAL (INTERVAL '1' MONTH) 7 (PARTITION P1 VALUES LESS THAN (TO_DATE('2010-3-28', 'YYYY-MM-DD')), 8 PARTITION P2 VALUES LESS THAN (TO_DATE('2010-4-1', 'YYYY-MM-DD'))); 表已创建。
复制
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
文章被以下合辑收录
评论
相关阅读
【纯干货】Oracle 19C RU 19.27 发布,如何快速升级和安装?
Lucifer三思而后行
797次阅读
2025-04-18 14:18:38
Oracle RAC 一键安装翻车?手把手教你如何排错!
Lucifer三思而后行
666次阅读
2025-04-15 17:24:06
Oracle数据库一键巡检并生成HTML结果,免费脚本速来下载!
陈举超
599次阅读
2025-04-20 10:07:02
【ORACLE】你以为的真的是你以为的么?--ORA-38104: Columns referenced in the ON Clause cannot be updated
DarkAthena
551次阅读
2025-04-22 00:13:51
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
536次阅读
2025-04-17 17:02:24
【ORACLE】记录一些ORACLE的merge into语句的BUG
DarkAthena
511次阅读
2025-04-22 00:20:37
一页概览:Oracle GoldenGate
甲骨文云技术
502次阅读
2025-04-30 12:17:56
火焰图--分析复杂SQL执行计划的利器
听见风的声音
472次阅读
2025-04-17 09:30:30
OR+DBLINK的关联SQL优化思路
布衣
384次阅读
2025-05-05 19:28:36
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
383次阅读
2025-04-15 14:48:05