如何在SQL中按WeekNO和Year计算月份的最后一周

如何在SQL中按WeekNO和Year计算月份的最后一周,第1张

如何在SQL中按WeekNO和Year计算月份的最后一周

如果您使用的是 SQL Server
,则可以使用主表来执行计算,而无需创建日历表。这位同事为您提供了很好的解释,建议您阅读。他的用于计算每个月的第一个和最后一个星期日的SQL可以适合您的使用:

declare @year intset @year =2011select min(dates) as first_sunday,max(dates) as last_sunday from(select dateadd(day,number-1,DATEADD(year,@year-1900,0))as dates from master..spt_valueswhere type='p' and number between 1 andDATEDIFF(day,DATEADD(year,@year-1900,0),DATEADD(year,@year-1900+1,0))) as twhere DATENAME(weekday,dates)='sunday'group by DATEADD(month,datediff(month,0,dates),0)

编辑: 一旦有了星期四的日期,就可以从该日期获得星期几,如下所示:

DECLARE @Dt datetimeSELECT @Dt='02-21-2008'SELECT DATEPART( wk, @Dt)


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5427366.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)

保存