簡體   English   中英

計算Sql中日期之間的年數

[英]Calculate Number of years between dates in Sql

我需要計算sql中兩個日期之間的完整年數。 我目前用來計算的查詢是

--Date1 > Date2
CASE
WHEN YEAR(Date1) = YEAR(Date2)
    THEN DATEDIFF(year, Date2, Date1)
WHEN YEAR(Date1) > YEAR(Date2) 
        AND MONTH(Date1) >= MONTH(Date2)
        AND DAY(Date1) >= DAY(Date2)
    THEN DATEDIFF(year, Date2, Date1)
ELSE
    DATEDIFF(year, Date2, Date1) - 1

但是我需要以某種方式調整它,以便它將2011年1月5日到2012年4月30日之間的時間視為1整年。

在比較之前將一天添加到Date2

dateadd(day, 1, Date2)

如果我們的目標是將一年的一年減少考慮為一年,那么只需將1天添加到您以后的日期即可? dateadd()應該這樣做。

mysql> SELECT ADDDATE('2011-05-01', INTERVAL 1 DAY);
        -> '2011-05-02'

認為這不會導致其他錯誤的計算......

暫無
暫無

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

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