有帮助吗?

解决方案

是能够

SET DATEFIRST 1; -- Monday

http://msdn.microsoft.com/en-us/library /ms181598.aspx

似乎DATEDIFF不尊重DATEFIRST,所以使它做这样的运行它

create table #testDates (id int identity(1,1), dateAdded datetime)
insert into #testDates values ('2009-07-09 15:41:39.510') -- thu
insert into #testDates values ('2009-07-06 15:41:39.510') -- mon
insert into #testDates values ('2009-07-05 15:41:39.510') -- sun
insert into #testDates values ('2009-07-04 15:41:39.510') -- sat

SET DATEFIRST 7 -- Sunday (Default
select * from #testdates where datediff(ww, DATEADD(dd,-@@datefirst,dateadded), DATEADD(dd,-@@datefirst,getdate())) = 0
SET DATEFIRST 1 -- Monday
select * from #testdates where datediff(ww, DATEADD(dd,-@@datefirst,dateadded), DATEADD(dd,-@@datefirst,getdate())) = 0

被盗

HTTP:// social.msdn.microsoft.com/Forums/en-US/transactsql/thread/8cc3493a-7ae5-4759-ab2a-e7683165320b

其他提示

我有另一种解决方案。 这应该是比较容易理解,纠正我,如果我错了

SET DATEFIRST 1
select DATEDIFF(week, 0, DATEADD(day, -@@DATEFIRST, '2018-04-15 00:00:00.000'))

我们从日期减去“-1”和周日将成为周六(这是一周的7nth日) 和Mondфy(2)将一周的第一天

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top