标题:关于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



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-318120-1-1.html




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

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