如何选择给定DateTime变量的月份的第一天?
我知道使用这种代码很容易做到:
select CAST(CAST(YEAR(@mydate) AS VARCHAR(4))
+ '/' + CAST(MONTH(@mydate) AS VARCHAR(2)) + '/01' AS DATETIME)
这不是很优雅,也不是很快。
还有更好的办法吗?
如何选择给定DateTime变量的月份的第一天?
我知道使用这种代码很容易做到:
select CAST(CAST(YEAR(@mydate) AS VARCHAR(4))
+ '/' + CAST(MONTH(@mydate) AS VARCHAR(2)) + '/01' AS DATETIME)
这不是很优雅,也不是很快。
还有更好的办法吗?
当前回答
DECLARE @startofmonth date
SET @startofmonth = DATEADD(dd,1,EOMONTH(Getdate(),-2))
-2会得到上个月的第一天。例如,getdate()是10/15/18。你的结果将是9/1/18。更改为-1,结果将是10/1/18。0是下个月的开始,2018年11月1日。等等。
or
DECLARE @startofmonth date
SET @startofmonth = DATEADD(dd,1,EOMONTH(@mydate,-1))
其他回答
SELECT DATEADD (DAY, -1 * (DAY(GETDATE()) - 1), GETDATE())
.....................................................................
如果你不想要时间,那么将其转换为日期,或者如果想要使时间为0:00:00,转换为日期,然后回到DATETIME。
SELECT CONVERT (DATETIME,
CONVERT (DATE, DATEADD (DAY, -1 * (DAY(GETDATE()) - 1),
GETDATE())))
将GETDATE()更改为所需的日期
它可能相当快。为什么不创建一个sql函数呢?
CREATE FUNCTION [dbo].[GetFirstDayOfMonth] ( @InputDate DATETIME )
RETURNS DATETIME
BEGIN
RETURN CAST(CAST(YEAR(@InputDate) AS VARCHAR(4)) + '/' +
CAST(MONTH(@InputDate) AS VARCHAR(2)) + '/01' AS DATETIME)
END
GO
在这里,我们可以使用下面的查询到每月的第一个日期和最后一个日期。
SELECT DATEADD(DAY,1,EOMONTH(Getdate(),-1)) as 'FD',Cast(Getdate()-1 as Date)
as 'LD'
从SQL Server 2012开始:
SELECT DATEADD(DAY,1,EOMONTH(@mydate,-1))
SELECT @myDate - DAY(@myDate) + 1