如何选择给定DateTime变量的月份的第一天?


我知道使用这种代码很容易做到:

select CAST(CAST(YEAR(@mydate) AS VARCHAR(4)) 
+ '/' + CAST(MONTH(@mydate) AS VARCHAR(2)) + '/01' AS DATETIME)

这不是很优雅,也不是很快。

还有更好的办法吗?


当前回答

在Sql Server 2012中

 select getdate()-DATEPART(day, getdate())+1

 select DATEADD(Month,1,getdate())-DATEPART(day, getdate())

其他回答

试试下面的方法:

select trunc(sysdate,'MM') 
from dual;

我使用GETDATE()作为一个日期来工作,你可以用你需要的日期替换它。 这是如何工作的:首先,我们将日期格式化为YYYYMMDD…格式截断,只保留最左边的6个字符,以便只保留YYYYMM部分,然后追加'01'作为月份——瞧!你有当月的第一天。

SELECT CAST(CONVERT(VARCHAR(6),GETDATE(),112) +'01' AS DATETIME) AS StartOfMonth

顺便说一句,性能是伟大的在这!

这个查询应该在MySQL上工作得很好:

SELECT concat(left(curdate(),7),'-01') 

这也是可行的:

    SELECT DATEADD(DAY,(DATEPART(DAY,@mydate)-1)*(-1),@mydate) AS FirstOfMonth

从SQL Server 2022,您可以使用DATETRUNC

SELECT DATETRUNC(month, @mydate)

为了这种需要