oracle 中的INTERVAL 函数解析学习笔记

  1. 简单层次解析:

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 '时间' <day/hour/minute/second> ;

例如 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 )

posted on   癫狂编程  阅读(3025)  评论(0编辑  收藏  举报

编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
历史上的今天:
2017-10-26 00405EB0 mov eax,dword ptr [ecx] 是什么意思?
2017-10-26 我常用的delphi 第三方控件
2017-10-26 淘宝卖家搜索器V1.6算法注册机。
2017-10-26 Delphi中Form的position属性与代码自定义窗体位置
2017-10-26 Delphi窗体部分属性

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
好的代码像粥一样,都是用时间熬出来的
点击右上角即可分享
微信分享提示