在 T-SQL 中检查两个日期之间的日期

Posted

技术标签:

【中文标题】在 T-SQL 中检查两个日期之间的日期【英文标题】:Check date between two dates in T-SQL 【发布时间】:2013-09-10 07:53:39 【问题描述】:

我有一个存储过程,想要检查日期是否在固定日期和当前日期/时间之间(使用GETDATE()):

SELECT
    a, b
FROM myTbl
WHERE
    DATE BETWEEN 'Day start datetime' AND GETDATE()

...例如:

WHERE
    DATE BETWEEN '2013-09-10 00:00:00.00' AND 'GETDATE()'

怎么做?

【问题讨论】:

【参考方案1】:

一对DATEADD/DATEDIFF 调用会将日期四舍五入到前一个午夜:

SELECT a , b
FROM myTbl
WHERE DATE BETWEEN DATEADD(day,DATEDIFF(day,0,GETDATE()),0) and GETDATE()

或者,如果您使用的是 SQL Server 2008 或更高版本:

SELECT a , b
FROM myTbl
WHERE DATE BETWEEN CONVERT(date,GETDATE()) and GETDATE()

【讨论】:

【参考方案2】:

'GETDATE()' 是字符串文字,GETDATE()T-SQL 函数。

您的查询应如下所示:

SELECT a , b
FROM myTbl
WHERE DATE BETWEEN '2013-09-10 00:00:00.0' and GETDATE()

【讨论】:

【参考方案3】:

我认为WHERE DATE BETWEEN '2013-09-10 00:00:00.00' and GETDATE()(在GETDATE() 调用周围没有单引号)应该可以正常工作。

【讨论】:

'2013-09-10 00:00:00.00' 例如,明天它将无法正常工作,我确定了当前日期开始时间 好的,我没有从问题中得到答案。正确答案由@Damien_The_Unbeliever 给出。【参考方案4】:

您可以通过将 Getdate() 返回值转换为 Date 类型并再次转换为 Datetime 来获取 Day start date time,如下所示。

select a,b
from myTbl
where [date] between convert(datetime,convert([date], getdate())) 
                 and getdate()

【讨论】:

以上是关于在 T-SQL 中检查两个日期之间的日期的主要内容,如果未能解决你的问题,请参考以下文章

在 T-SQL 中比较日期,忽略时间部分

需要 mongodb 查询来检查日期是不是在存储在集合文档中的两个日期之间[重复]

检查当前日期是不是在两个日期之间 Oracle SQL

如何检查今天是不是在 Twig 的两个日期之间?

检查日期是不是在另一个数据框中的两个日期之间,如果是则操作日期

检查两个日期之间的时间戳