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)
轉載于:https://www.cnblogs.com/lonelyxmas/p/8862992.html
總結
以上是生活随笔為你收集整理的SQL获取当月天数的几种方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 写扩展性好的代码:函数
- 下一篇: 第一周Access课总结