首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用GETDATE()从表中拉出

使用GETDATE()从表中拉出
EN

Stack Overflow用户
提问于 2018-07-17 05:07:02
回答 1查看 27关注 0票数 -1

对于这个基本的(可能也是愚蠢的)问题,我要提前道歉。

我正在执行SELECT查询,其中我连接了几个表。我有一个表,其中包含与某些日期相关联的数值。我希望在我的输出中包含今天附加的数值,但我不知道如何实现这一点。显然,对于输出中的每条记录,我都会有相同的值,我对此没有意见。

这有可能吗?如果是这样,代码的示例是什么?

我希望从中得到数值的表只在一列中有日期(Calendar_Day),在另一列中有整数(X_Value)。下面,您可以看到我的SELECT语句的最后三行。最近一次尝试的结果为空。

代码语言:javascript
复制
,[EnterpriseDB].[pcc].[conditions].Internal
,GETDATE() AS Date_Today 
,(SELECT [X_Value] FROM [Analytics].[WorkArea].[Days_Vals] WHERE [Calendar_Day] = GETDATE()) AS BizVal_Today
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 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()

代码语言:javascript
复制
... WHERE [Calendar_Day] = convert(date, getdate()) ...

如果[Calendar_Day]也是一个datetime,但您不想比较小时(、分钟、秒...)它的一部分,也向下投射它。

代码语言:javascript
复制
... WHERE convert(date, [Calendar_Day]) = convert(date, getdate()) ...

但是,如果在[Calendar_Day]上有一些索引,可能会抛出任何索引。如果这会导致任何性能问题,您可能需要考虑将数据类型更改为date,或者使用持久的索引计算列并与之进行比较。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51370120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档