T-SQL里,关于当月有多少天的问题

 

思路是取得本月的最后一天,之后再取改天的日期号即可

**千万注意不能用下一个月的今天,和本月今天作datediff

如果这样的话,当本月有31号,而下一个月没有31号时得到的将是下一个月的天数

   SELECT   Day ( dateadd (ms, - 3 , DATEADD (mm,  DATEDIFF (m, 0 , getdate ()) + 1 , 0 ))) 
-- 存取思路是取得下一个月的第一天,之后再向前推一天,就是本月的最后一天 
--
其中 select DATEDIFF(m,0,getdate()) --会得到本月的月份号与公元1000年之间的差距, 
--
注意得到的是今天和公元1000年做比较的月份差 -
- 不是与公元0年的月份差,如果今天是2008年2月11日,执行该语句的结果是1297 
--  +1后得到下个月的月份数 
select   DATEADD (mm,  DATEDIFF (m, 0 , getdate ()) + 1 , 0
-- 将得到下个月的1号的0分0秒 
select   dateadd (ms, - 3 , DATEADD (mm,  DATEDIFF (m, 0 , getdate ()) + 1 , 0 ))) 
-- 将向前推3秒,得到本月份的最后一天
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值