oracle sysdate - interval '7',oracle 中的INTERVAL 函数解析学习笔记

简单层次解析:

select sysdate - interval '10' day as "10天前",

sysdate - interval '10' hour as "10小时前",

sysdate - interval '10' minute as "10分钟前",

sysdate - interval '10' second as "10秒钟前",

sysdate - 10 as "10天前",

sysdate - 10 / 24 as "10小时前",

sysdate - 10 / (24 * 60) as "10分钟前",

sysdate - 10 / (24 * 3600) as "10秒钟前"

from dual;

这里的 interval表示某段时间,格式是: interval '时间' ;

例如 interval '10' day 表示10天

2. 深层次解析:

INTERVAL YEAR TO MONTH数据类型

Oracle语法:

INTERVAL 'integer [- integer]' {YEAR | MONTH} [(precision)][TO {YEAR | MONTH}]

该数据类型常用来表示一段时间差, 注意时间差只精确到年和月. precision为年或月的精确域, 有效范围是0到9, 默认值为2.

eg:

INTERVAL '123-2' YEAR(3) TO MONTH

表示: 123年2个月, "YEAR(3)" 表示年的精度为3, 可见"123"刚好为3为有效数值, 如果该处YEAR(n), n<3就会出错, 注意默认是2.

INTERVAL '123' YEAR(3)

表示: 123年0个月

INTERVAL '300' MONTH(3)

表示: 300个月, 注意该处MONTH的精度是3啊.

INTERVAL '4' YEAR

表示: 4年, 同 INTERVAL '4-0' YEAR TO MONTH 是一样的

INTERVAL '50' MONTH

表示: 50个月, 同 INTERVAL '4-2' YEAR TO MONTH 是一样

INTERVAL '123' YEAR

表示: 该处表示有错误, 123精度是3了, 但系统默认是2, 所以该处应该写成 INTERVAL '123' YEAR(3) 或"3"改成大于3小于等于9的数值都可以的

INTERVAL '5-3' YEAR TO MONTH + INTERVAL '20' MONTH =

INTERVAL '6-11' YEAR TO MONTH

表示: 5年3个月 + 20个月 = 6年11个月

3. 日常应用案例:

查询5年内的订单信息

select from oe.orders where order_date < (SYSDATE - INTERVAL '5' YEAR )

标签:sysdate,10,INTERVAL,MONTH,123,YEAR,oracle,解析

来源: https://www.cnblogs.com/jijm123/p/13880614.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值