sql server日期查询语句(SQL Server中查询结果超出了查询时间范围解决方法)
sql server日期查询语句
SQL Server中查询结果超出了查询时间范围解决方法废话少说,直接上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'
其实如果细看过文档的话,应该知道是什么原因,因为数据类型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语句得出的结果在逻辑上就有误。
官方文档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查询超时的知识点内容,感谢大家的而学习和对开心学习网的支持。
- mysql缓存和redis查询效率(浅谈MySQL与redis缓存的同步方案)
- 查询mysql 死锁(MySQL线上死锁分析实战)
- python中怎么连接mysql(python远程连接MySQL数据库)
- laravel终止函数执行(laravel 输出最后执行sql 附:whereIn的使用方法)
- mysql多表连接优化(浅谈Mysql多表连接查询的执行细节)
- sqlserver 多实例怎么算许可(SQL Server使用row_number分页的实现方法)
- python下的sql处理(python中aioysql异步操作MySQL的方法)
- mysql 操作日志(MySQL中的undo日志)
- django怎么设置数据库(django配置连接数据库及原生sql语句的使用方法)
- mysql怎么和sqlyog连接(Mysql桌面工具之SQLyog资源及激活使用方法告别黑白命令行)
- dedecms v5.7使用教程(织梦dedecms数据库类$dsql使用方法步骤)
- mysql怎么看脱机数据(MYSQL电话号码,身份证数据脱敏的实现)
- sqlserver2008数据库的备份(sql server 2008 压缩备份数据库20g)
- SqlTransaction事务的用法
- sqlserver2008远程连接设置(如何开启SqlServer 远程访问)
- mysql的binlog几种模式(MySQL系列之redo log、undo log和binlog详解)
- 点赞 禹州苌庄正式撤乡建镇 未来发展不可估量(禹州苌庄正式撤乡建镇)
- 它荣获 中国生态魅力镇 称号 就在咱们禹州,一起来看看(中国生态魅力镇)
- 真牛 禹州将建成中等城市(禹州将建成中等城市)
- 被骂欺师灭祖,与郭德纲公开叫板,何云伟改名何沄伟,开始画画了(与郭德纲公开叫板)
- 相声转行影帝,被何晴抛弃,甩10年女友闪婚生子,刘威不靠谱情史(相声转行影帝被何晴抛弃)
- 岳云鹏不说相声,改行演员了 网友 快回来说相声(岳云鹏不说相声)
热门推荐
- python自动解数独教学(Python判断有效的数独算法示例)
- python ssh 连接(python pexpect ssh 远程登录服务器的方法)
- C#中的反射
- h1标签和h3标签怎么找(H1标签使用的七大注意事项推荐)
- markdown和python的关系(解决python Markdown模块乱码的问题)
- win10下安装mysql8.0.23 及 “服务没有响应控制功能”问题解决办法(win10下安装mysql8.0.23 及 “服务没有响应控制功能”问题解决办法)
- nginx 反向代理的参数(Nginx反向代理及负载均衡如何实现基于linux)
- sql中where和having可以同时用吗(SQL where条件和jion on条件的详解及区别)
- jquery中prop和attr的区别
- vuex中action的值怎么接(vuex中Getter的用法详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9