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

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

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语句得出的结果在逻辑上就有误。

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

其实这个是精度问题,如果选择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查询超时的知识点内容,感谢大家的而学习和对的支持。

更多相关文章

  1. MySQL 5.7.9 服务无法启动-“NET HELPMSG 3534”的解决方法
  2. android中HttpURLConnection调用getResponseCode()时崩溃 解决方
  3. Android空引用问题的解决方法——on a null object reference
  4. android读取assets大于1M文件的解决方法
  5. 几个Android小错误解决方法
  6. CheckBox android:paddingLeft 不兼容问题解决方法
  7. Android(安卓)Studio使用过程中遇到的问题(一)-- "value 2"异常解
  8. Eclipse中编译Android工程时出现的问题解决方法。
  9. Android(安卓)ListView滑动后背景变黑问题解决方法

随机推荐

  1. android 开发时出现 Please ensure that
  2. 让TextView 自带滚动条
  3. Android:TextView 自动滚动(跑马灯)
  4. React Navigation Android(安卓)返回键事
  5. Android中常用的XML生成方法实例分析
  6. adb 全部命令
  7. (二)Android系统信息
  8. Android 自定义View(手写签名)
  9. Android平台开发-Android keypad map-And
  10. DDM dispatch reg wait timeout , Can't