SQL Server如何查找季度、半年和当年的最后一天?

Posted

技术标签:

【中文标题】SQL Server如何查找季度、半年和当年的最后一天?【英文标题】:How to find the last day of a Quarter, Half Year and Year of current Year in SQL Server? 【发布时间】:2020-05-12 05:51:24 【问题描述】:

我想在 SQL Server 中获取季度、半年和当年的最后一天。假设当前日期为 2020 年 5 月 12 日,季度结束日期为 2020 年 6 月 30 日,半年日期为 2020 年 6 月 30 日,年结束日期为 2020 年 12 月 31 日。

我可以使用 DATEADD 和 DATEDIFF 内置函数获取季度和年份的最后日期,但无法获取半年的最后日期。 任何帮助,将不胜感激。

【问题讨论】:

【参考方案1】:

由于您标记datediff,这是使用dateadd / datediff 的解决方案

; with dates as
(
    select  [date] = convert(date, '2020-01-01')
    union all
    select  [date] = dateadd(month, 1, [date])
    from    dates
    where   [date]  < '2020-12-01'
)
select  [date],
        dateadd(quarter, datediff(quarter, 0, [date]) + 1, -1) as [Last Day of Quarter],
        dateadd(quarter, datediff(quarter, 0, [date]) / 2 * 2 + 2, -1) as [Last Day of Half Year],
        dateadd(year, datediff(year, 0, [date]) + 1, -1) as [Last Day of Year]
from    dates

db<>fiddle

【讨论】:

以上是关于SQL Server如何查找季度、半年和当年的最后一天?的主要内容,如果未能解决你的问题,请参考以下文章

sql 在SQL中查找季度的最后一天

SQL Server学习记录之获取每月每季度每年第一天和最后一天

如何在 SQL Server 中获取一个季度的上个月数据?

如何在 SQL Server 中查找上次修改表的人?

SQL 2005 查询本周/本月/本季度/本年的数据

计数SQL,查找单据总量和按季度查找单据总量