首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL多重差异

SQL多重差异
EN

Stack Overflow用户
提问于 2010-01-11 00:20:48
回答 1查看 567关注 0票数 4

当我在SQL Server2005/2008上对DECIMAL数字进行乘法运算时,我偶然发现了这个奇怪的现象。有没有人能解释这种影响?

代码语言:javascript
复制
DECLARE @a DECIMAL(38,20)
DECLARE @b DECIMAL(38,20)
DECLARE @c DECIMAL(38,20)

SELECT  @a=1.0,
        @b=2345.123456789012345678,
        @c=23456789012345.999999999999999999

SELECT CASE WHEN @a*@b*@c = @c*@b*@a
       THEN 'Product is the same'
       ELSE 'Product differs'
       END
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-01-11 00:23:55

这是由于精确表示和舍入误差造成的。

这个问题是由于

代码语言:javascript
复制
SELECT @a*@b   --(=2345.123457)

请在SO中搜索多个示例。

相关:Sql Server Decimal(30,10) losing last 2 decimals

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2037598

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档