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

作者:拥有永远握在我手中 时间:2024-01-18 04:05:54 

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


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

来源:https://www.cnblogs.com/lonelyxmas/p/11833851.html

标签:SQL,Server,查询超时
0
投稿

猜你喜欢

  • JavaScript闭包与作用域链实例分析

    2024-04-10 10:48:55
  • 解析Golang中的GoPath和GoModule

    2024-05-09 14:56:48
  • 详解Python3中的迭代器和生成器及其区别

    2022-11-01 00:37:48
  • 超详细注释之OpenCV制作图像Mask

    2021-10-20 14:15:34
  • Python抓取通过Ajax加载数据的示例

    2023-12-09 21:28:38
  • 高亮闪烁某个元素的js脚本

    2024-04-16 09:04:27
  • 使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二)

    2023-04-25 19:32:40
  • golang 格式化输入输出操作

    2024-04-25 15:10:24
  • Python爬虫自动化爬取b站实时弹幕实例方法

    2023-03-21 04:45:42
  • Python‘==‘ 及 ‘is‘相关原理解析

    2021-10-11 15:16:59
  • 细品Dreamweaver MX 内建FW技术

    2008-06-04 09:41:00
  • python爬取代理IP并进行有效的IP测试实现

    2021-05-08 15:31:38
  • Python+Seaborn绘制分布图的示例详解

    2021-08-14 16:51:29
  • 浅谈vue获得后台数据无法显示到table上面的坑

    2024-05-13 09:07:16
  • Mysql 乘法除法精度不一致问题(除法后四位小数)

    2024-01-13 09:44:16
  • ASP网页编程的19个基本技巧

    2023-07-09 11:52:01
  • python基础篇之pandas常用基本函数汇总

    2021-09-06 20:42:22
  • python如何代码集体右移

    2023-07-08 01:34:28
  • Python自定义聚合函数merge与transform区别详解

    2022-09-14 11:45:30
  • django中url映射规则和服务端响应顺序的实现

    2023-04-21 09:58:27
  • asp之家 网络编程 m.aspxhome.com