SQL语句取不出的数据?奇怪!

KaoShi 2000-07-04 11:01:00
ACCESS库中有表Test包含若干字段:
其中有Coll字段;
Numbers字段为[数字单精度型,小数位4]。
ASP中使用SQL语句:
select Coll from Test where Numbers=774.1234
此时库中明明有Numbers为774.1234的值,但取不出Collect值?#$@%
(服务器为NT4+IIS4)
后来解决方法有二:
1.将Number字段改为[整型],问题消失;
2.移asp文件至WIN98+PWS4,同样的SQL语句居然选出了值?!
岂不是很奇怪??
望各位大侠指点迷津!!不胜感激。
...全文
196 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
zzh 2000-07-16
  • 打赏
  • 举报
回复
操作系统处理浮点数有不同的规则,所以不能用比较两数相等的方法,而应该在一个精度范围内.这样就不会出错了。
KaoShi 2000-07-15
  • 打赏
  • 举报
回复
问题的关键在:
为什么NT+IIS4不行,而WIN98+PWS就可以???
为什么???
zigzag 2000-07-05
  • 打赏
  • 举报
回复
用select Coll from Test where abs(Numbers-774.1234)<0.0001,
单精度数存放时有精度问题,实际上可能存的不是777.1234,后面可能还有更多的小数位。
Tyro 2000-07-05
  • 打赏
  • 举报
回复
尽量不要比较浮点数的相等,很不可靠!

28,390

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧