[英]Check date between two dates in T-SQL
我有一个存储过程,想要检查日期是否在固定日期和当前日期/时间之间(使用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()'
怎么做?
一对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()
'GETDATE()'
是字符串文字, GETDATE()
是T-SQL
函数。
您的查询应如下所示:
SELECT a , b
FROM myTbl
WHERE DATE BETWEEN '2013-09-10 00:00:00.0' and GETDATE()
我认为WHERE DATE BETWEEN '2013-09-10 00:00:00.00' and GETDATE()
(在GETDATE()
调用周围没有单引号)应该可以正常工作。
您可以通过将 Getdate() 返回值转换为 Date 类型并再次转换为 Datetime 来获取Day start date time
,如下所示。
select a,b
from myTbl
where [date] between convert(datetime,convert([date], getdate()))
and getdate()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.