计算Sql中日期之间的年数

时间:2011-12-06 13:13:10

标签: sql sql-server

我需要计算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日之间的时间视为一整年。

2 个答案:

答案 0 :(得分:4)

在比较之前将一天添加到Date2

dateadd(day, 1, Date2)

答案 1 :(得分:0)

如果我们的目标是将一年中的一年减少为一年,那么只需在一天之后添加一天即可? dateadd()应该这样做。

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

认为会导致其他错误的计算......