SQL Server在SQL Server取出上个月的第一天

DECLARE @FIRSTDAYatCurrentMonth DATETIME
SELECT @FIRSTDAYatCurrentMonth = (DATEADD(MM,DATEDIFF(MM,0,getdate()),0))
SELECT DATEADD (MM,-1,@FIRSTDAYatCurrentMonth)

切切实实作求上个月第一天:

使用DATEADD()与DATEDIFF()函数来取出。前者以Interval单位展开加减,后者是以Interval单位总括差别 。

 

 

例如:
 DATEADD(MM , -1, GETDATE())
即是说脚下日子减去一,即是上个月当前的日期时间。
 DATEDIFF(MM,0,getdate()) 
统计出来的值就是眼今天子与1900-01相相差月数。

DECLARE @LASTMONTH datetime
SELECT @LASTMONTH=(SELECT DATEADD(MM,-1, GETDATE()))
SELECT DATEADD(MM, DATEDIFF(MM,0,@LASTMONTH),0)   

或者求出当月的首先天,然后再用DATEADD()来处理求得上个月率后天:

相关文章