0

在这种类型的代码中,

AND Orders.ShipDate >= DATEADD(Day, Datediff(Day,0, GetDate() -6), 0)

它应该提取日期为 6 天前的记录,直到今天。我怎样才能让它从 7 天前到昨天拉记录?

我知道更改-6-7将提取 7 天前的记录,但哪个变量是日期跨度的结束,所以我可以将其更改为-1

4

4 回答 4

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 天前当天午夜的日期,以及今天午夜之前的日期(即昨天的任何时间)。

于 2012-02-06T23:31:05.780 回答
0

“日期范围的结束”不在您的查询中。

将您的代码更改为:

AND (Orders.ShipDate BETWEEN DATEADD(Day, -1, GetDate()) AND DATEADD(Day, -7, GetDate()))

于 2012-02-06T23:27:56.197 回答
0

这也应该有效,它消除了不必要的 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
于 2012-02-07T00:16:45.247 回答
0

我喜欢 BETWEEN 函数。这可能与您使用的 SQL 风格不同,但这是我使用的。

BETWEEN dateadd(second, 0, dateadd(dd,datediff(dd,7,getdate()),0)) AND dateadd(second,-1, dateadd(dd,datediff(dd,0,getdate()),0))  
于 2016-04-26T19:36:08.573 回答