• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
素蔓、无暇至永恒
承诺总是那么不堪一击~
博客园    首页    新随笔    联系   管理    订阅  订阅

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()+(32-Day(getdate())))
 5,同上
select 50-DAY(GETDATE()-DAY(GETDATE())+50)

posted @ 2012-08-23 17:15  pain1033  阅读(6129)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3