天天看點

SQL擷取當月天數的幾種方法

原文:

SQL擷取當月天數的幾種方法

日期直接減去int類型的數字 等于 DATEADD(DAY,- 數字,日期)

下面三種方法:

1,日期加一個月減去目前天數,相當于這個月最後一天的日期。然後擷取天數。(注意,不能用這種方式:目前日期減去目前天數,再加一個月,新日期不一定是目前月的最後一天的日期。比如目前月是3月。錯誤:select day(dateadd(month,1,getdate()-day(getdate()))))

select day(dateadd(mm,1,getdate())-day(getdate()))

2,convert把日期轉換成120格式的是 "2011-1-1"這種格式。

     最終也是得到這個月最後一天。然後擷取天數。

select day( dateadd(day,-1, dateadd(month,1,convert(char(07),getdate(),120)+'-01')) ),

3,下個月的今天與和今天的日期差  。 (這個月剩下的日期+已經過去的日期)

select datediff(dd , GETDATE(), dateadd(mm, 1,GETDATE()))

4,下面這個方法很犀利。

      先得到上個月的最後一天,然後加一個天數(黑色标記),這個天數隻要大于一個月小于兩個月的天數即可。

      得到下個月的日期。然後用這個天數減去新生成的日期多出來的天數,即目前月的天數。

select 32-DAY(GETDATE()-DAY(GETDATE())+32)

 5,同上

select 50-DAY(GETDATE()-DAY(GETDATE())+50)