我需要把分钟转换成小时,四舍五入到小数点后两位。我还需要只显示小数点后最多两个数字。如果分钟是650,那么小时应该是10.83。

以下是我目前所了解到的:

Select round(Minutes/60.0,2) from ....

但是在这种情况下,如果我的分钟是630小时是10500万。但我只希望它是10.50(四舍五入后)。我该如何做到这一点?


当前回答

你可以使用:

select cast((630/60.0) as decimal(16,2))

SQL Server

其他回答

我发现STR函数是完成这一任务的最干净的方法。

SELECT STR(ceiling(123.415432875), 6, 2)

四舍五入到小数点后x位:

SET @Result = CEILING(@Value * POWER(10, @Decimals)) / POWER(10, @Decimals)

其中@Value是要四舍五入的项的值,@Decimals是小数点后的位数,例如,在本例中是两位。

这适用于PostgreSQL和Oracle:

SELECT ename, sal, round(((sal * .15 + comm) /12),2)
FROM emp where job = 'SALESMAN'
Declare @number float = 35.44987665;
Select round(@number,2) 

你可以使用:

select cast((630/60.0) as decimal(16,2))

SQL Server