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 )


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM