我正在尝试确定在SQL中截断或删除额外的小数位而不舍入的最佳方法。例如:

declare @value decimal(18,2)

set @value = 123.456

这将自动将@value舍入为123.46,这在大多数情况下都很好。然而,对于这个项目,我不需要那样。有没有一种简单的方法来截断我不需要的小数?我知道我可以使用left()函数并将其转换回小数。还有别的办法吗?


当前回答

我知道这有点晚了,但我不认为这是一个答案,我已经使用这个技巧很多年了。

只需从值中减去0.005并使用Round(@num,2)。

你的例子:

declare @num decimal(9,5) = 123.456

select round(@num-.005,2)

返回123.45

它会自动调整四舍五入到您正在寻找的正确值。

顺便问一下,你是在重现电影《办公空间》里的程序吗?

其他回答

ROUND(number, decimals, operation)

number =>必选参数。要四舍五入的数字 decimals =>必选。要四舍五入的小数位数 operation =>可选。如果是0,则将结果四舍五入为小数。如果其他值大于0,则将结果截断为小数的个数。默认值为0

SELECT ROUND(235.415, 2, 1)

给你235.410

SELECT ROUND(235.415, 0, 1)

给你23.5万

但是现在你可以使用cast

SELECT CAST(ROUND(235.415, 0, 1) AS INT)

会得到235

我知道这有点晚了,但我不认为这是一个答案,我已经使用这个技巧很多年了。

只需从值中减去0.005并使用Round(@num,2)。

你的例子:

declare @num decimal(9,5) = 123.456

select round(@num-.005,2)

返回123.45

它会自动调整四舍五入到您正在寻找的正确值。

顺便问一下,你是在重现电影《办公空间》里的程序吗?

请尝试使用此代码将一个点后的3个十进制值转换为2位小数:

declare @val decimal (8, 2)
select @val = 123.456
select @val =  @val

select @val

输出值为123.46

SELECT Cast(Round(123.456,2,1) as decimal(18,2))

另一个没有舍入解决方案的截断和示例。

    Convert 71.950005666 to a single decimal place number (71.9)
    1) 71.950005666 * 10.0 = 719.50005666
    2) Floor(719.50005666) = 719.0
    3) 719.0 / 10.0 = 71.9

    select Floor(71.950005666 * 10.0) / 10.0