
我今天和昨天订了订单(18,17)
我要找到那些结果。
select A.C_Name
from Customer_Table A
inner join
Order_Table O
On A.C_ID=O.C_ID
where DATEPART(DAY,Order_Date)=GetDATE() and
DATEPART(DAY,Order_Date)=GETDATE()-1我没有得到上述查询的结果。
发布于 2017-11-18 17:40:18
如果你想要今天和昨天的订单,那么这就足够了:
where Order_Date >= dateadd(day, -1, cast(getdate() as date))(这假定没有未来的订单日期,似乎是合理的)。
您的查询由于以下几个原因而变得一团糟。datepart()返回一个整数,并将其与日期进行比较。看一看日期的“一天”部分,在一个月的第一天就行不通了。而且,getdate() --尽管它的名字--有时间成分,所以直接相等是不合适的。
https://stackoverflow.com/questions/47369034
复制相似问题