Oracle使用range分区并根据时间列自动创建分区

 更新时间:2023年04月18日 10:12:01   作者:傻啦猫@_@  
这篇文章主要介绍了Oracle使用range分区并根据时间列自动创建分区,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Oracle使用range分区,根据时间列自动创建分区

-- Create table
create table MY_TEST 
(
    id    NUMBER (12) not null,
    name    VARCHAR2 (12) not null,
    today    TIMESTAMP (6) default SYSDATE
)
partition by range (today) interval(numtodsinterval(1,'day')) --月分区用month,年分区用year
(
    partition P_20230411 values less than (TO_DATE('2023-04-12 00:00:00,"SYYYY-MM-DD HH24:MI:SS"))
        tablespace TB_SAMS
        pctfree 10
        initrans 1
        maxtrans 255
        storage
        (
            initial 1M
            next 1M
            minextents 1
            maxextents unlimited
        )
);
- - Add comments to the table
comment on table MY_TEST
    is ‘测试表';
Add comments to the columns
comment on column MY_TEST.id
    is ‘主键id';
comment on column MY_TEST.name
    is ‘名称';
comment on column MY_TEST.today
    is ‘时间';

- - Create/Recreate indexes
create index MY_TEST_INDEX on MY_TEST (id)
    tablespace TB_SAMS
    pctfree 10
    initrans 2
    maxtrans 255
    storage
    (
        initial 64K
        next 1M
        minextents 1
        maxextents unlimited
);
- -Grant/Revoke object privileges
grant select on MY_TEST to DBVIEW;

INSERT INTO MY_TEST VALUES (1,'xxc1',SYSDATE);
INSERT INTO MY_TEST VALUES (2,'xxc2'‚SYSDATE+1);
INSERT INTO MY_TEST VAIUES (3,'xxc3',SYSDATE+2) ;

测试效果

附录oracle 根据日期自动生成分区表

oracle 根据日期自动生成分区表

CREATE TABLE my_table (
  id NUMBER,
  name VARCHAR2(50),
  created_date DATE
)
PARTITION BY RANGE (created_date) INTERVAL (NUMTODSINTERVAL(1, 'DAY'))
(
  PARTITION p1 VALUES LESS THAN (TO_DATE('2022-01-01', 'YYYY-MM-DD'))
);

其中:

numtodsinterval(,) ,x是一个数字,c是一个字符串,
表明x的单位,这个函数把x转为interval day to second数据类型

常用的单位有 (‘day’,‘hour’,‘minute’,‘second’)

numtoymintervalnumtodsinterval函数类似,将x转为interval year to month数据类型

常用的单位有(‘year’,‘month’)

格式:NumToYMInterval(n, interval_unit);

n: 数值类型

interval_unit: ‘YEAR’, ‘MONTH’ ,或其他可以转换成这两个值之一的表达式

NumToYMInterval(1, ‘YEAR’) :一年后的间隔

NumToYMInterval(-1, ‘MONTH’): 一个月前

小数会被计算成整数后,再做计算:

select sysdate + numtoyminterval(0.1, 'MONTH')  from dual;
2023-03-21 09:54:37

如果执行含有函数的sql时报错:”INTERVAL YEAR TO MONTH literal“。不能与数值做运算。

常用用途:

做日期运算时,这个函数非常有用。例如:取一个月后的日期:

select sysdate + NumToYMInterval(1, 'MONTH') from dual;

到此这篇关于Oracle使用range分区并根据时间列自动创建分区的文章就介绍到这了,更多相关Oracle自动创建分区内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle在PL/SQL中使用子查询

    Oracle在PL/SQL中使用子查询

    这篇文章介绍了Oracle在PL/SQL中使用子查询的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle23ai 新特性IF [NOT] EXISTS语法支持的使用

    Oracle23ai 新特性IF [NOT] EXISTS语法支持的使用

    IF [NOT] EXISTS语法用于抑制因给定对象的存在或不存在而引发的潜在错误,允许您编写幂等DDL脚本,本文主要介绍了Oracle23ai 新特性IF [NOT] EXISTS语法支持的使用,感兴趣的可以了解一下
    2024-08-08
  • Oracle静态注册与动态注册详解

    Oracle静态注册与动态注册详解

    这篇文章主要介绍了Oracle静态注册与动态注册,需要的朋友可以参考下
    2014-07-07
  • Oracle数据库concat()函数用法及使用简化的‘||’进行拼接

    Oracle数据库concat()函数用法及使用简化的‘||’进行拼接

    CONCAT()函数在Oracle中可以用于将两个字符串连接在一起,那么CONCAT()函数的语法及使用方法是什么呢,这篇文章主要给大家介绍了关于Oracle数据库concat()函数用法及使用简化的‘||’进行拼接的相关资料,需要的朋友可以参考下
    2024-03-03
  • Oracle LogMiner的使用实例代码

    Oracle LogMiner的使用实例代码

    这篇文章主要给大家分享了关于Oracle LogMiner的使用实例代码,文中通过示例代码介绍了关于查询当前日志组、业务用户插入操作、归档日志切换、业务用户插入操作以及归档日志切换等等的相关功能,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-07-07
  • 通过sql准确查出一天数据的方法

    通过sql准确查出一天数据的方法

    之前做一个项目的时候想用sql查出某人一天做的数据,但怎么查都没有准确查出。最近通过查阅万卷书籍终于知道了如何准确查出一天的数据。所以想着总结出来分享给大家,或许对有需要的朋友们能带来一定的帮助,下面来一起看看吧。
    2016-12-12
  • 浅谈入门级oracle数据库数据导入导出步骤

    浅谈入门级oracle数据库数据导入导出步骤

    这篇文章主要介绍了浅谈入门级oracle数据库数据导入导出步骤,文章通过步骤解析介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Oracle system/用户被锁定的解决方法

    Oracle system/用户被锁定的解决方法

    很多人对oracle数据库会将用户锁定感觉莫名其妙,所以下面这篇文章主要介绍了Oracle system/用户被锁定的解决方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • Oracle 11g Release (11.1) 索引底层的数据结构

    Oracle 11g Release (11.1) 索引底层的数据结构

    本文介绍关于 Oracle 索引的结构。大概了解 Oracle 索引底层的数据结构,从而更好地理解 Oracle 索引对增、删、改、查的性能
    2012-11-11
  • Oracle约束管理脚本

    Oracle约束管理脚本

    Oracle约束管理脚本...
    2007-03-03

最新评论