gpt4 book ai didi

sql - SQL Server 2016 中与小数相乘会导致值不正确

转载 作者:行者123 更新时间:2023-12-03 09:09:21 24 4
gpt4 key购买 nike

当我运行查询时:

(SELECT (CONVERT(DECIMAL, COUNT(SequenceId)) * 0.6)  FROM dbo.usvSequenceToSequence_WithSequenceId)

我得到的结果是:17550.0

但是,当我运行查询时:

DECLARE @percentageOfSliceAsDecimal DECIMAL
SET @percentageOfSliceAsDecimal = 0.6
(SELECT (CONVERT(DECIMAL, COUNT(SequenceId)) * @percentageOfSliceAsDecimal) FROM dbo.usvSequenceToSequence_WithSequenceId)

我得到的结果是:29250

为什么会发生这种情况?

最佳答案

您需要以适当的精度声明:

declare @d decimal(10,2) = 0.6
select(convert(decimal,1982)*@d)

返回 1189.20

如果我们只有小数

declare @d decimal = 0.6
select(convert(decimal,1982)*@d)

四舍五入为 1,返回 1982

关于sql - SQL Server 2016 中与小数相乘会导致值不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44188097/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com