亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何確定SQL Server中一個月中的天數?

如何確定SQL Server中一個月中的天數?

小怪獸愛吃肉 2019-12-25 15:39:48
我需要確定SQL Server中給定日期的月份中的天數。有內置功能嗎?如果沒有,我應該使用什么作為用戶定義的函數?
查看完整描述

3 回答

?
縹緲止盈

TA貢獻2041條經驗 獲得超4個贊

您可以在指定月份的第一天使用以下命令:


datediff(day, @date, dateadd(month, 1, @date))

要使它適用于每個日期:


datediff(day, dateadd(day, 1-day(@date), @date),

              dateadd(month, 1, dateadd(day, 1-day(@date), @date)))


查看完整回答
反對 回復 2019-12-25
?
肥皂起泡泡

TA貢獻1829條經驗 獲得超6個贊

在SQL Server 2012中,可以使用EOMONTH(Transact-SQL)來獲取月份的最后一天,然后可以使用DAY(Transact-SQL)來獲取月份中的天數。


DECLARE @ADate DATETIME


SET @ADate = GETDATE()


SELECT DAY(EOMONTH(@ADate)) AS DaysInMonth


查看完整回答
反對 回復 2019-12-25
?
慕俠2389804

TA貢獻1719條經驗 獲得超6個贊

最優雅的解決方案:適用于任何@DATE


DAY(DATEADD(DD,-1,DATEADD(MM,DATEDIFF(MM,-1,@DATE),0)))

將其扔到函數中或直接內聯使用。這將回答原始問題,而其他答案中沒有所有多余的垃圾。


來自其他答案的日期示例:


SELECT DAY(DATEADD(DD,-1,DATEADD(MM,DATEDIFF(MM,-1,'1/31/2009'),0))) 返回31


SELECT DAY(DATEADD(DD,-1,DATEADD(MM,DATEDIFF(MM,-1,'2404-feb-15'),0))) 返回29


SELECT DAY(DATEADD(DD,-1,DATEADD(MM,DATEDIFF(MM,-1,'2011-12-22'),0))) 返回31


查看完整回答
反對 回復 2019-12-25
  • 3 回答
  • 0 關注
  • 687 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號