От округлых до n значимых цифр в SQL
Я хотел бы иметь возможность округлять число до n значительных цифр в SQL. Итак:
123.456 rounded to 2sf would give 120
0.00123 rounded to 2sf would give 0.0012
Мне известна функция ROUND(), которая округляется до n знаков после запятой, а не значительных цифр.
Ответы
Ответ 1
select round(@number,@sf-1- floor(log10(abs(@number))))
должен сделать трюк!
Успешно протестировано на двух примерах.
Изменить: вызов этой функции на @number = 0 не будет работать. Перед использованием этого кода вы должны добавить тест для этого.
create function sfround(@number float, @sf int) returns float as
begin
declare @r float
select @r = case when @number = 0 then 0 else round(@number ,@sf -1-floor(log10(abs(@number )))) end
return (@r)
end
Ответ 2
Вы можете разделить на 100 до округления, а затем умножить на 100...
Ответ 3
Думаю, я справился с этим.
CREATE FUNCTION RoundSigFig(@Number float, @Figures int)
RETURNS float
AS
BEGIN
DECLARE @Answer float;
SET @Answer = (
SELECT
CASE WHEN intPower IS NULL THEN 0
ELSE FLOOR(fltNumber * POWER(CAST(10 AS float), intPower) + 0.5)
* POWER(CAST(10 AS float), -intPower)
END AS ans
FROM (
SELECT
@Number AS fltNumber,
CASE WHEN @Number > 0
THEN -((CEILING(LOG10(@Number)) - @Figures))
WHEN @Number < 0
THEN -((FLOOR(LOG10(@Number)) - @Figures))
ELSE NULL END AS intPower
) t
);
RETURN @Answer;
END
Ответ 4
Адаптирован самый популярный ответ Бранна в MySQL для тех, кто похож на меня.
CREATE FUNCTION `sfround`(num FLOAT, sf INT) # creates the function
RETURNS float # defines output type
DETERMINISTIC # given input, will return same output
BEGIN
DECLARE r FLOAT; # make a variable called r, defined as a float
IF( num IS NULL OR num = 0) THEN # ensure the number exists, and isn't 0
SET r = num; # if it is; leave alone
ELSE
SET r = ROUND(num, sf - 1 - FLOOR(LOG10(ABS(num))));
/* see below*/
END IF;
RETURN (r);
END
/* Чувствовал себя слишком долго, чтобы вставить комментарий */
ROUND (num, sf - 1 - FLOOR (LOG10 (ABS (num))))
- Часть, которая выполняет эту работу, использует функцию ROUND на номере как обычно, но рассчитывается длина округленной до
- ABS обеспечивает положительный
- LOG10 получает число цифр больше 0 в числе
- FLOOR получает наибольшее целое число меньше результирующего числа
- Так всегда округляется и дает целое число
- sf - 1 - FLOOR (...) дает отрицательное число
-
работает, потому что раунды ROUND (num, -ve num) слева от десятичной точки
-
Всего за один раз, ROUND (123.456, -1) и ROUND (0.00123,4)
вернуть запрошенные ответы ((120, 0.0012)