填写isoweek的月份

cyej8jka  于 2021-07-29  发布在  Java
关注(0)|答案(1)|浏览(307)

首先,很抱歉我的专栏太长了,我不得不把它全部贴出来,这样你才能更好地理解我的苦衷。
我有一个日期和一周的日历。
我要做的是创建另一个列来表示该日期的月份。编号将从1开始,将有一个完整的一周和一个完整的一个月。
例如,1月将在2月2日结束,因为1月的最后一整周从2月开始。我尝试了很多解决方案,比如将isoweek转换为isomonth,但都没有得到预期的结果。
感谢您的帮助。
编辑:感谢alex,下面的解决方案是:

SELECT month(dateadd(d, 3, dateadd(WEEK, datediff(WEEK, 0, DATEADD(d,-1,'20200302')), 0)))
TheDate   IsoWeek  The Month---I want to add this 
12/30/2019  1       1
12/31/2019  1       1
1/1/2020    1       1
1/2/2020    1       1
1/3/2020    1       1
1/4/2020    1       1
1/5/2020    1       1
1/6/2020    2       1
1/7/2020    2       1
1/8/2020    2       1
1/9/2020    2       1
1/10/2020   2       1
1/11/2020   2       1
1/12/2020   2       1
1/13/2020   3       1
1/14/2020   3       1
1/15/2020   3       1
1/16/2020   3       1
1/17/2020   3       1
1/18/2020   3       1
1/19/2020   3       1
1/20/2020   4       1
1/21/2020   4       1
1/22/2020   4       1
1/23/2020   4       1
1/24/2020   4       1
1/25/2020   4       1
1/26/2020   4       1
1/27/2020   5       1
1/28/2020   5       1
1/29/2020   5       1
1/30/2020   5       1
1/31/2020   5       1
2/1/2020    5       1
2/2/2020    5       1
2/3/2020    6       2
2/4/2020    6       2
2/5/2020    6       2
2/6/2020    6       2
2/7/2020    6       2
2/8/2020    6       2
2/9/2020    6       2
2/10/2020   7       2
2/11/2020   7       2
2/12/2020   7       2
2/13/2020   7       2
2/14/2020   7       2
2/15/2020   7       2
2/16/2020   7       2
2/17/2020   8       2
2/18/2020   8       2
2/19/2020   8       2
2/20/2020   8       2
2/21/2020   8       2
2/22/2020   8       2
2/23/2020   8       2
2/24/2020   9       2
2/25/2020   9       2
2/26/2020   9       2
2/27/2020   9       2
2/28/2020   9       2
2/29/2020   9       2
3/1/2020    9       2
3/2/2020    10      3
3/3/2020    10      3
3/4/2020    10      3
3/5/2020    10      3
3/6/2020    10      3
3/7/2020    10      3
3/8/2020    10      3
3/9/2020    11      3
3/10/2020   11      3
3/11/2020   11      3
3/12/2020   11      3
3/13/2020   11      3
3/14/2020   11      3
3/15/2020   11      3
3/16/2020   12      3
3/17/2020   12      3
3/18/2020   12      3
3/19/2020   12      3
3/20/2020   12      3
3/21/2020   12      3
3/22/2020   12      3
3/23/2020   13      3
3/24/2020   13      3
3/25/2020   13      3
3/26/2020   13      3
3/27/2020   13      3
3/28/2020   13      3
3/29/2020   13      3
3/30/2020   14      3
3/31/2020   14      3
4/1/2020    14      3
4/2/2020    14      3
4/3/2020    14      3
4/4/2020    14      3
4/5/2020    14      3
rqmkfv5c

rqmkfv5c1#

iso周从星期一开始,因此给定周的月/年总是等于该周星期四的月/年。您可以通过截短日期列,然后添加3天来获得此结果,如下所示:

ALTER TABLE calendar ADD TheMonth int;
UPDATE calendar SET TheMonth = month(dateadd(DAY, 3, dateadd(WEEK, datediff(WEEK, 0, TheDate), 0)))

编辑:我已经减去一天的工作时间

SELECT month(dateadd(d, 3, dateadd(WEEK, datediff(WEEK, 0, dateadd(d,-1,TheDate)), 0)))

相关问题