我正在尝试确定在SQL中截断或删除额外的小数位而不舍入的最佳方法。例如:
declare @value decimal(18,2)
set @value = 123.456
这将自动将@value舍入为123.46,这在大多数情况下都很好。然而,对于这个项目,我不需要那样。有没有一种简单的方法来截断我不需要的小数?我知道我可以使用left()函数并将其转换回小数。还有别的办法吗?
我正在尝试确定在SQL中截断或删除额外的小数位而不舍入的最佳方法。例如:
declare @value decimal(18,2)
set @value = 123.456
这将自动将@value舍入为123.46,这在大多数情况下都很好。然而,对于这个项目,我不需要那样。有没有一种简单的方法来截断我不需要的小数?我知道我可以使用left()函数并将其转换回小数。还有别的办法吗?
当前回答
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
其他回答
以下是我能够截断而不是舍入的方法:
select 100.0019-(100.0019%.001)
返回100.0010
你的例子是:
select 123.456-(123.456%.001)
返回123.450
现在,如果你想去掉0结尾,只需对它进行强制转换:
select cast((123.456-(123.456%.001)) as decimal (18,2))
返回123.45
你到底要不要小数点?
如果没有,请使用
select ceiling(@value),floor(@value)
如果你用0做,那么做一轮:
select round(@value,2)
请尝试使用此代码将一个点后的3个十进制值转换为2位小数:
declare @val decimal (8, 2)
select @val = 123.456
select @val = @val
select @val
输出值为123.46
SELECT CAST(Value as Decimal(10,2)) FROM TABLE_NAME;
小数点后会有两个值。(mssql server)
另一个没有舍入解决方案的截断和示例。
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