如何通过EOMONTH函数在SQL Server中轻松获取指定月份的最后一天?
- 内容介绍
- 相关推荐
本文共计816个文字,预计阅读时间需要4分钟。
如果您想修改上述内容,以下是一个简化的版本:
最常用写法:
SELECT EOMONTH(GETDATE()) AS LastDayOfThisMonth;结果是类似2024-06-30这样的日期值,类型和输入一致(GETDATE()返回datetime,结果也是datetime)。
- 想指定具体某个月?直接传入该月任意一天,比如
EOMONTH('2024-02-15')→2024-02-29 - 要上个月最后一天?第二个参数填
-1:EOMONTH(GETDATE(), -1) - 下个月最后一天?填
1:EOMONTH(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分钟。
如果您想修改上述内容,以下是一个简化的版本:
最常用写法:
SELECT EOMONTH(GETDATE()) AS LastDayOfThisMonth;结果是类似2024-06-30这样的日期值,类型和输入一致(GETDATE()返回datetime,结果也是datetime)。
- 想指定具体某个月?直接传入该月任意一天,比如
EOMONTH('2024-02-15')→2024-02-29 - 要上个月最后一天?第二个参数填
-1:EOMONTH(GETDATE(), -1) - 下个月最后一天?填
1:EOMONTH(GETDATE(), 1) - 注意:第二个参数只接受整数,不支持小数或表达式(如
YEAR(GETDATE())不能直接塞进去)
不用EOMONTH时的替代方案容易出错
老版本SQL Server(2008及更早)没这个函数,常见补救写法是:
SELECT DATEADD(DAY, -1, DATEADD(MONTH, 1, DATEFROMPARTS(YEAR(GETDATE()), MONTH(GETDATE()), 1)))逻辑是“先取当月1号 → 加1个月 → 减1天”。

