簡體   English   中英

將年份連接到Oracle SQL中的日期

[英]Concatenate year to a date in Oracle SQL

我正在嘗試使查詢動態化,以查找一年中兩天(去年7月1日至今年6月30日)之間的所有日期。 以下是我一直在嘗試的查詢的where子句:

and pbh.batch_date between
        ('30-JUN-'||extract(year from trunc(sysdate))-1))
    and ('01-JUL-'||extract(year from trunc(sysdate))))

這將返回不一致的數據類型錯誤:預期DATE得到NUMBER。 然后,我嘗試將它們強制轉換為類似這樣的日期:

and pbh.batch_date between
        to_date(( '01-JUL-'||extract(year from trunc(sysdate))-1))
    and to_date(( '30-JUN-'||extract(year from trunc(sysdate))))

但這現在返回一個無效的數字錯誤。 我不知道pbh.batch_date是以什么格式存儲的,但這是(m)m /(d)d / yyyy

無需強制轉換為字符串並返回:

and ph.batch_date >= add_months(trunc(sysdate,'YEAR'), -6) 
and ph.batch_date <  add_months(trunc(sysdate,'YEAR'), 6)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM