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

declare @value decimal(18,2)

set @value = 123.456

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


当前回答

你到底要不要小数点?

如果没有,请使用

select ceiling(@value),floor(@value)

如果你用0做,那么做一轮:

select round(@value,2)

其他回答

你到底要不要小数点?

如果没有,请使用

select ceiling(@value),floor(@value)

如果你用0做,那么做一轮:

select round(@value,2)

我知道这个问题非常古老,但没有人使用子字符串舍入。这是对很长的数字进行四舍五入的优势(SQL server中字符串的限制通常是8000个字符):

SUBSTRING('123.456', 1, CHARINDEX('.', '123.456') + 2)

如果你想要取一些像89.0904987这样的数字,并通过省略不需要的小数位将其转换为89.09,只需使用以下方法:

select cast(yourColumnName as decimal(18,2))

下面的截图来自W3Schools SQL数据类型部分,它描述了decimal(18,2)的作用:

因此,

select cast(89.0904987 as decimal(18,2))

给你:89.09

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

试着这样做:

SELECT cast(round(123.456,2,1) as decimal(18,2))