| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 403 人关注过本帖
标题:关于between...and....的问题
只看楼主 加入收藏
南川
Rank: 4
等 级:业余侠客
威 望:1
帖 子:111
专家分:235
注 册:2010-6-25
结帖率:86.21%
收藏
已结贴  问题点数:20 回复次数:3 
关于between...and....的问题
CREATE TABLE dbo.DateTest(
  PK INT IDENTITY,
  OrderDate DATETIME
  )
go
INSERT dbo.DateTest(OrderDate)
  VALUES('10/9/01 00:00')
INSERT dbo.DateTest(OrderDate)
  VALUES('10/9/01 23:59')
INSERT dbo.DateTest(OrderDate)
  VALUES('10/9/01 11:59:59.995 pm')
INSERT dbo.DateTest(OrderDate)
  VALUES('10/9/02');

建一张表
图片附件: 游客没有浏览图片的权限,请 登录注册


执行查询语句
SELECT *
  FROM dbo.DateTest
  WHERE OrderDate BETWEEN '10/9/1' AND '10/9/1 11:59:59.998 PM';
结果如下
图片附件: 游客没有浏览图片的权限,请 登录注册


问题:为什么第3条数据不是23:59:59.995而是997?
搜索更多相关主题的帖子: 查询 
2010-09-04 10:41
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:10 
为什么不是995?应该是存储误差问题

★★★★★为人民服务★★★★★
2010-09-04 17:02
qingshuiliu
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:17
帖 子:323
专家分:1538
注 册:2009-12-28
收藏
得分:10 
datatime可以精确到3%秒(3.33毫秒)
摘自MSDN:
datetime 秒的小数部分精度的舍入
将 datetime 值舍入到 .000、.003、或 .007 秒的增量。
所以当值为 11:59:59.99X的时候,最好就会变成11:59:59.993,11:59:59.997,如果是11:59:59.999就会成为增加一天,后面全为零。
2010-09-05 07:47
南川
Rank: 4
等 级:业余侠客
威 望:1
帖 子:111
专家分:235
注 册:2010-6-25
收藏
得分:0 
原来如此。。。。Thank you........
2010-09-05 09:12
快速回复:关于between...and....的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014212 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved