首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用getdate()

使用getdate()
EN

Stack Overflow用户
提问于 2015-04-17 18:27:34
回答 3查看 72关注 0票数 0

我正在使用下面的查询

代码语言:javascript
复制
SELECT *
    FROM [dbo].[QUANTITY] 
    WHERE getdate() BETWEEN fromdate AND todate

如果todatenull (1900-01-01 00:00:00.000),它只会过滤掉它们。我甚至希望使用todate的字段在结果中是null (1900-01-01 00:00:00.000)。这是如何做到的呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-04-17 18:33:44

您可以使用andor运算符的组合显式地检查它:

代码语言:javascript
复制
SELECT *
FROM   [dbo].[QUANTITY] 
WHERE  (getdate() >= fromdate AND
        (todate IS NULL OR
         todate = '1900-01-01 00:00:00.000')
       ) OR
       getdate() BETWEEN fromdate AND todate
票数 2
EN

Stack Overflow用户

发布于 2015-04-17 18:43:59

这条线上似乎有一个.Net或某个程序保存Date.MinValue,如果应用程序无法替换,则始终可以在

代码语言:javascript
复制
datefromparts(1900,1,1)

并将where子句更改为:

代码语言:javascript
复制
where getdate() > fromdate
and (todate = datefromparts(1900,1,1) or getdate() <= todate)

这将占用最大或无限制的日期。如果可能的话,为了防止出现奇怪的结果,我也会用

代码语言:javascript
复制
declare @testDate datetime = getdate(); 

并在前面的where子句中使用该变量,而不是getdate()。

票数 0
EN

Stack Overflow用户

发布于 2015-04-17 18:52:37

代码语言:javascript
复制
SELECT *
FROM [dbo].[QUANTITY] 
WHERE getdate() >= fromdate
  AND getdate() <= COALESCE(todate
                           ,NULLIF(todate,'1900-01-01 00:00:00.000')
                           ,'9999-12-31 23:59:59.997'
                           )
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29706804

复制
相关文章

相似问题

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