gpt4 book ai didi

SQL Server中查询结果超出了查询时间范围解决方法

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章SQL Server中查询结果超出了查询时间范围解决方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

废话少说,直接上SQL代码(有兴趣的测试验证一下),下面这个查询语句为什么将2008-11-27的记录查询出来了呢?这个是同事遇到的一个问题,个人设计了一个例子.

?
1
2
3
4
5
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'

SQL Server中查询结果超出了查询时间范围解决方法

  。

其实如果细看过文档的话,应该知道是什么原因,因为数据类型Datetiem的时间范围:00:00:00 到 23:59:59.997 , 最后部分的范围为0 ~997,官方文档提示,datetime的秒的小数部分精度的有舍入,具体请见下面 。

datetime 秒的小数部分精度的舍入 。

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

用户指定的值 。

系统存储的值 。

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 。

实验测试验证,998会转换为997,而'2008-11-26 23:59:59.999'的话,就会转换为'2008-11-27 00:00:00.000',如下截图所示,所以尤其对数据精确性有要求的地方,要注意这些地方,否则SQL语句得出的结果在逻辑上就有误.

SQL Server中查询结果超出了查询时间范围解决方法

官方文档https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/datetime-transact-sql?view=sql-server-ver15 中也有描述不准确的地方,如下截图所示:  。

SQL Server中查询结果超出了查询时间范围解决方法

其实这个是精度问题,如果选择datetime2数据类型,它默认的小数精度更高,不会遇到这个问题,更多细节建议参考官方文档(下面参考资料) 。

参考资料:

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 。

以上就是本次介绍的关于SQL Server查询超时的知识点内容,感谢大家的而学习和对我的支持.

原文链接:https://www.cnblogs.com/lonelyxmas/p/11833851.html 。

最后此篇关于SQL Server中查询结果超出了查询时间范围解决方法的文章就讲到这里了,如果你想了解更多关于SQL Server中查询结果超出了查询时间范围解决方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com