博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL获取当月天数的几种方法
阅读量:6936 次
发布时间:2019-06-27

本文共 765 字,大约阅读时间需要 2 分钟。

日期直接减去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)

转载于:https://www.cnblogs.com/howie/archive/2012/08/23/2652802.html

你可能感兴趣的文章
MySQL日志审计 帮你揪出内个干坏事儿的小子
查看>>
PureFTPD配置指南
查看>>
存储虚拟化技术之解读
查看>>
VMware View 5.0从菜鸟到高手系列 10 –远程图形工作站配置篇
查看>>
《VMware虚拟化与计算应用案例详解》第三次印刷!
查看>>
阻止保存要求重新创建表的更改
查看>>
成长的故事
查看>>
open***负载均衡高可用多种方案实战讲解01(老男孩主讲)
查看>>
SQL Server 2012笔记分享-12:理解备份与恢复新特性
查看>>
FAQ:configuration manager未找到站点来管理此客户端
查看>>
TiDB VS MariaDB10.1.19 Enterprise性能压测
查看>>
百度云同步盘网络异常【1】解决办法(续)
查看>>
谁动了我的文件?
查看>>
京东刘强东的3次大抉择
查看>>
手机多图传输神器-快传正式版抢先评测
查看>>
分享三种简单的推广渠道,玩转引流精准粉
查看>>
U2L蔚然成风,曙光为什么能抢了VMware的风头?
查看>>
MySQL基础备忘(2)之视图
查看>>
MapGuide OpenSource 2.2 安装中的数字签名错误
查看>>
ubuntu分区
查看>>