如何通过EOMONTH函数在SQL Server中轻松获取指定月份的最后一天?

2026-05-06 19:420阅读0评论SEO资讯
  • 内容介绍
  • 相关推荐

本文共计816个文字,预计阅读时间需要4分钟。

如何通过EOMONTH函数在SQL Server中轻松获取指定月份的最后一天?

如果您想修改上述内容,以下是一个简化的版本:

最常用写法:

SELECT EOMONTH(GETDATE()) AS LastDayOfThisMonth;结果是类似2024-06-30这样的日期值,类型和输入一致(GETDATE()返回datetime,结果也是datetime)。

  • 想指定具体某个月?直接传入该月任意一天,比如EOMONTH('2024-02-15')2024-02-29
  • 要上个月最后一天?第二个参数填-1EOMONTH(GETDATE(), -1)
  • 下个月最后一天?填1EOMONTH(GETDATE(), 1)
  • 注意:第二个参数只接受整数,不支持小数或表达式(如YEAR(GETDATE())不能直接塞进去)

不用EOMONTH时的替代方案容易出错

老版本SQL Server(2008及更早)没这个函数,常见补救写法是:

SELECT DATEADD(DAY, -1, DATEADD(MONTH, 1, DATEFROMPARTS(YEAR(GETDATE()), MONTH(GETDATE()), 1)))逻辑是“先取当月1号 → 加1个月 → 减1天”。

阅读全文

本文共计816个文字,预计阅读时间需要4分钟。

如何通过EOMONTH函数在SQL Server中轻松获取指定月份的最后一天?

如果您想修改上述内容,以下是一个简化的版本:

最常用写法:

SELECT EOMONTH(GETDATE()) AS LastDayOfThisMonth;结果是类似2024-06-30这样的日期值,类型和输入一致(GETDATE()返回datetime,结果也是datetime)。

  • 想指定具体某个月?直接传入该月任意一天,比如EOMONTH('2024-02-15')2024-02-29
  • 要上个月最后一天?第二个参数填-1EOMONTH(GETDATE(), -1)
  • 下个月最后一天?填1EOMONTH(GETDATE(), 1)
  • 注意:第二个参数只接受整数,不支持小数或表达式(如YEAR(GETDATE())不能直接塞进去)

不用EOMONTH时的替代方案容易出错

老版本SQL Server(2008及更早)没这个函数,常见补救写法是:

SELECT DATEADD(DAY, -1, DATEADD(MONTH, 1, DATEFROMPARTS(YEAR(GETDATE()), MONTH(GETDATE()), 1)))逻辑是“先取当月1号 → 加1个月 → 减1天”。

阅读全文