欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

MsSql

當(dāng)前位置:主頁 > 數(shù)據(jù)庫 > MsSql >

SQL Server中查詢結(jié)果超出了查詢時(shí)間范圍解決方法

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:MsSql|點(diǎn)擊: 次

廢話少說,直接上SQL代碼(有興趣的測試驗(yàn)證一下),下面這個(gè)查詢語句為什么將2008-11-27的記錄查詢出來了呢?這個(gè)是同事遇到的一個(gè)問題,個(gè)人設(shè)計(jì)了一個(gè)例子。

USE AdventureWorks2014;
GO
SELECT * FROM [Person].[Person]
WHERE ModifiedDate >= '2008-11-26 00:00:00:000'
 AND ModifiedDate <= '2008-11-26 23:59:59.999'

 

其實(shí)如果細(xì)看過文檔的話,應(yīng)該知道是什么原因,因?yàn)閿?shù)據(jù)類型Datetiem的時(shí)間范圍:00:00:00 到 23:59:59.997 , 最后部分的范圍為0 ~997,官方文檔提示,datetime的秒的小數(shù)部分精度的有舍入,具體請見下面

datetime 秒的小數(shù)部分精度的舍入

如下表所示,將 datetime 值舍入到 .000、.003、或 .007 秒的增量 。

用戶指定的值

系統(tǒng)存儲的值

01/01/98 23:59:59.999

1998-01-02 00:00:00.000

01/01/98 23:59:59.995

01/01/98 23:59:59.996

01/01/98 23:59:59.997

01/01/98 23:59:59.998

1998-01-01 23:59:59.997

01/01/98 23:59:59.992

01/01/98 23:59:59.993

01/01/98 23:59:59.994

1998-01-01 23:59:59.993

01/01/98 23:59:59.990

01/01/98 23:59:59.991

1998-01-01 23:59:59.990

實(shí)驗(yàn)測試驗(yàn)證,998會轉(zhuǎn)換為997,而'2008-11-26 23:59:59.999'的話,就會轉(zhuǎn)換為'2008-11-27 00:00:00.000',如下截圖所示,所以尤其對數(shù)據(jù)精確性有要求的地方,要注意這些地方,否則SQL語句得出的結(jié)果在邏輯上就有誤。

官方文檔https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/datetime-transact-sql?view=sql-server-ver15 中也有描述不準(zhǔn)確的地方,如下截圖所示: 

其實(shí)這個(gè)是精度問題,如果選擇datetime2數(shù)據(jù)類型,它默認(rèn)的小數(shù)精度更高,不會遇到這個(gè)問題,更多細(xì)節(jié)建議參考官方文檔(下面參考資料)

參考資料:

https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/datetime2-transact-sql?view=sql-server-ver15

https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/datetime-transact-sql?view=sql-server-ver15

以上就是本次介紹的關(guān)于SQL Server查詢超時(shí)的知識點(diǎn)內(nèi)容,感謝大家的而學(xué)習(xí)和對我們的支持。

上一篇:SqlServer中批量update語句

欄    目:MsSql

下一篇:SQL SERVER日志進(jìn)行收縮的圖文教程

本文標(biāo)題:SQL Server中查詢結(jié)果超出了查詢時(shí)間范圍解決方法

本文地址:http://mengdiqiu.com.cn/a1/MsSql/10284.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有