簡體   English   中英

在 T-SQL 中檢查兩個日期之間的日期

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM