![](/img/trans.png)
[英]SQL Query to provide data from yesterday between and including 12:00 AM to 11:59 PM
[英]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.