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

时间:2013-09-10 07:53:40

标签: sql-server tsql between

我有一个存储过程,要检查日期是否在固定日期和当前日期/时间之间(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()'

怎么做?

4 个答案:

答案 0 :(得分:14)

一对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()

答案 1 :(得分:6)

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

您的查询应如下所示:

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

答案 2 :(得分:1)

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

答案 3 :(得分:0)

您可以通过将Getdate()返回值转换为Date类型并再次转换为Datetime来获得Day start date time

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