标题:sql小数相乘出现零值问题
取消只看楼主
wuyongjun198
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2015-5-15
结帖率:0
已结贴  问题点数:20 回复次数:0 
sql小数相乘出现零值问题
1.
 select  cast( 0.0050000000 as decimal(38,23)) * cast(0.0000010000 as decimal(38,23)),此sql结果为何为0
 select  cast( 0.0050000000 as decimal(28,23)) * cast(0.0000010000 as decimal(28,23)) ,此sql值又不为零

2.
 select  cast( 0.01 as decimal(28,15)) * cast(0.0000000001 as decimal(28,15))  结果为零
select  cast( 0.01 as decimal(28,16)) * cast(0.0000000001 as decimal(28,16))  结果不为零


 我理解的sql小数相乘是这样的:
1.不同精度小数相乘,得出的结果小数精度会跟最大精度小数一致
2.当结果超出最大精度时,会按最大精度做四舍五入



 现在看到的情况完全不明白发生了什么!
2015-05-15 17:38



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




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

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