FIX: 除以负十进制或数字的数字结果中的 0 0

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 285544
本文已归档。它按“原样”提供,并且不再更新。
BUG #: 203148 (SHILOH_bugs)
症状
时使用十进制或数字数据类型,如果 0 除以一个负号,负 0 (-0),则返回。
解决方案
若要解决此问题,获得最新的 service pack,对于 SQL Server 2000。有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
290211INF: 如何获取最新的 SQL Server 2000 Service Pack
替代方法
在执行除法和所涉及的 0 ; 如果避免划分之前检查 0,例如:
declare @v1 dec(10, 2), @v2 dec(2, 1), @v3 dec (10,2) -- @v3 is the result of @v1/@v2select @v1 = 0.0, @v2 = -1.0if @v1 = 0     select @v3 = 0.0else   select @v3 = @v1 / @v2				
状态
Microsoft 已经确认这是 SQL Server 2000 中的问题。此问题 SQL Server 2000 Service Pack 1 中第一次已得到纠正。
更多信息
SQL Server 不考虑计算的值 (-0) 等于 0,因此计算值的比较结果 (-0) 与 0 失败。例如对于下面的代码
   declare @v1 dec(10, 2), @v2 dec(2, 1)   select @v1 = 0.0, @v2 = -1.0   if @v1 / @v2 = 0        print 'equals zero'   else      print 'not equal zero'				
授予以下结果:
   not equal zero 				
有关 SQL Server 7.0 中的相关错误的其他信息,请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
275608FIX: 数字或小数的数学运算带有负号的列可能会返回意外的结果

警告:本文已自动翻译

属性

文章 ID:285544 - 上次审阅时间:01/16/2015 21:25:27 - 修订版本: 3.2

Microsoft SQL Server 2000 标准版

  • kbnosurvey kbarchive kbmt kbbug kbfix kbsqlserv2000sp1fix KB285544 KbMtzh
反馈