zoukankan      html  css  js  c++  java
  • 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 )

    好的代码像粥一样,都是用时间熬出来的
  • 相关阅读:
    docker 第六篇 dockerfile
    docker 第五篇 存储
    8.4总结
    消失之物,分治
    NOIP模拟9
    卡特兰数总结
    【洛谷】P3537 [POI2012]SZA-Cloakroom
    0915 N校联考
    [树链剖分]BZOJ3589动态树
    0905膜你赛测试
  • 原文地址:https://www.cnblogs.com/jijm123/p/13880614.html
Copyright © 2011-2022 走看看