我想四舍五入5.457845
的十进制值。
- 如果小数点后的第一个数字值大于
5
则5.5
- 如果小数点后的第一个数字值小于
5
则5.0
例如:
5.457845 = 5.0
5.684575 = 5.5
这个怎么样:
select floor(5.457845 * 2) / 2 -- returns 5.0
select floor(5.684575 * 2) / 2 -- returns 5.5
select floor(5.0 * 2) / 2 -- corner case 1 - returns 5.0
select floor(5.4999999 * 2) / 2 -- corner case 2 - returns 5.0
select floor(5.5 * 2) / 2 -- corner case 3 - returns 5.5
select floor(5.9999999 * 2) / 2 -- corner case 4 - returns 5.5
请注意,这可能不适用于负数:
select floor(-5.0 * 2) / 2 -- corner case 5 - returns -5.0
select floor(-5.4999999 * 2) / 2 -- corner case 6 - returns -5.5
select floor(-5.5 * 2) / 2 -- corner case 7 - returns -5.5
select floor(-5.9999999 * 2) / 2 -- corner case 8 - returns -6.0
我认为没有任何本机函数可以做到这一点。试试这个技巧
DECLARE @num NUMERIC(22, 6) = 5.684575
SELECT Floor(@num) + CASE WHEN Round(@num, 1, 1) % 1 <= 0.5 THEN 0 ELSE 0.5 END
结果 : 5.5
如果数字可以是负数,那么您需要在函数之上使用ABS
函数ROUND
函数
ABS(Round(@num, 1, 1)) % 1