zoukankan      html  css  js  c++  java
  • 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)

  • 相关阅读:
    四十一.redis主从复制 RDB/AOF持久化 数据类型
    四十.创建Redis集群 管理集群
    三十九.NoSQL概述 部署Redis服务 、 部署LNMP+Redis
    三十八. 分库分表概述 配置mycat
    520D
    442C
    LA4788
    LA3276
    LA4122
    zoj3478
  • 原文地址:https://www.cnblogs.com/howie/p/2652802.html
Copyright © 2011-2022 走看看