簡體   English   中英

SQL查詢從上午12:00開始

[英]SQL query to start from hour 12:00 am

我有一個像這樣的日期列7/24/2017,當我寫下面的where子句時,我從7/24/2017 1:00:00.000 AM獲得了結果。 我需要從7/24/2017 12:00:00.000 AM獲取此信息。 我的where子句應該如何修改。 請檢查以下代碼

Date>= DATEADD(day, -1, convert(date, GETDATE())) and 
Date< DATEADD(day, +0,  convert(date, GETDATE()))

您的代碼似乎沒有任何問題。 您確定您的數據包含凌晨1點之前的任何時間嗎? 您確定您欣賞SQLServer如何格式化這些時間/將它們表示給您嗎?

請參閱以下SQLFIDDLE: http ://sqlfiddle.com/#!6/047cc/11

優化:您不需要將日期加0即可。您還可以從日期中減去1.0以使日期更早,並且比DATEADD少了一些麻煩。 之所以起作用,是因為內部日期表示為自某個時間點以來的天數的浮點數:

[Date] >= convert(date, GETDATE() -1.0) and 
[Date] < convert(date, GETDATE())

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

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