在这种类型的代码中,
AND Orders.ShipDate >= DATEADD(Day, Datediff(Day,0, GetDate() -6), 0)
它应该提取日期为 6 天前的记录,直到今天。我怎样才能让它从 7 天前到昨天拉记录?
我知道更改-6
为-7
将提取 7 天前的记录,但哪个变量是日期跨度的结束,所以我可以将其更改为-1
?
在这种类型的代码中,
AND Orders.ShipDate >= DATEADD(Day, Datediff(Day,0, GetDate() -6), 0)
它应该提取日期为 6 天前的记录,直到今天。我怎样才能让它从 7 天前到昨天拉记录?
我知道更改-6
为-7
将提取 7 天前的记录,但哪个变量是日期跨度的结束,所以我可以将其更改为-1
?
这不是日期跨度。
你所拥有的条件实际上只有一个条件:大于。大于的右侧是 6 天前,因此您的条件匹配任何晚于 6 天前的日期。换句话说,它不会止于今天;它包括明天、下周和明年。
AND ( Orders.ShipDate >= DATEADD(Day, Datediff(Day,0, GetDate() -7), 0)
AND Orders.ShipDate < DATEADD(Day, Datediff(Day,0, GetDate()), 0) )
这才是你真正想要的。它匹配晚于 7 天前当天午夜的日期,以及今天午夜之前的日期(即昨天的任何时间)。
“日期范围的结束”不在您的查询中。
将您的代码更改为:
AND (Orders.ShipDate BETWEEN DATEADD(Day, -1, GetDate()) AND DATEADD(Day, -7, GetDate()))
这也应该有效,它消除了不必要的 0 天添加:
select *,DATEDIFF(Day, orders.ShipDate, GETDATE()) AS DAYS_SINCE_TODAY
from Orders
where DATEDIFF(Day, orders.ShipDate, GETDATE()) >= 1 AND --This many days since today
DATEDIFF(Day, orders.ShipDate, GETDATE()) <= 7 --Going back this many days
我喜欢 BETWEEN 函数。这可能与您使用的 SQL 风格不同,但这是我使用的。
BETWEEN dateadd(second, 0, dateadd(dd,datediff(dd,7,getdate()),0)) AND dateadd(second,-1, dateadd(dd,datediff(dd,0,getdate()),0))