对于这个基本的(可能也是愚蠢的)问题,我要提前道歉。
我正在执行SELECT查询,其中我连接了几个表。我有一个表,其中包含与某些日期相关联的数值。我希望在我的输出中包含今天附加的数值,但我不知道如何实现这一点。显然,对于输出中的每条记录,我都会有相同的值,我对此没有意见。
这有可能吗?如果是这样,代码的示例是什么?
我希望从中得到数值的表只在一列中有日期(Calendar_Day),在另一列中有整数(X_Value)。下面,您可以看到我的SELECT语句的最后三行。最近一次尝试的结果为空。
,[EnterpriseDB].[pcc].[conditions].Internal
,GETDATE() AS Date_Today
,(SELECT [X_Value] FROM [Analytics].[WorkArea].[Days_Vals] WHERE [Calendar_Day] = GETDATE()) AS BizVal_Today
发布于 2018-07-17 05:48:52
只是猜测:
[Calendar_Day]
的类型为date
。而getdate()
返回一个datetime
。这意味着数据库管理系统将[Calendar_Day]
向上转换为时间为00:00:00.0的datetime
,以便能够比较操作数。但getdate()
包含当前时间。因此,除非您正好在00:00:00.0执行查询,否则这些值将不匹配,并且子查询返回null。
为了解决这个问题,向下转换getdate()
。
... WHERE [Calendar_Day] = convert(date, getdate()) ...
如果[Calendar_Day]
也是一个datetime
,但您不想比较小时(、分钟、秒...)它的一部分,也向下投射它。
... WHERE convert(date, [Calendar_Day]) = convert(date, getdate()) ...
但是,如果在[Calendar_Day]
上有一些索引,可能会抛出任何索引。如果这会导致任何性能问题,您可能需要考虑将数据类型更改为date
,或者使用持久的索引计算列并与之进行比较。
https://stackoverflow.com/questions/51370120
复制相似问题