SQL Server中Between在查詢日期時有30秒的誤差

來源:互聯網
上載者:User

在SQL Server 2005 SP3環境下,今天偶然使用Between查詢日期資料時,發現以下奇怪現象:其中PaymentDate為Smalldatetime

難道2011-07-31 23:59:59還在2011-08-01 0:00:00之外?

繼續嘗試,發現將時間減少31秒時,才真正達到想要的效果,如下:

小結:在用Between限制時間範圍時,範圍的邊界值應該向內收縮31秒,以達到真正符合需求的時間範圍。

不知道這是否算是“可忽略的誤差”?

補充:

後來查看MSDN知:(http://msdn.microsoft.com/zh-cn/library/ms182418.aspx)

smalldatetime的時間誤差為1分鐘,小於或等於 29.998 秒的值向下舍入為最接近的分鐘數;大於或等於 29.999 秒的值向上舍入為最接近的分鐘數。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.