Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.12.31;
Скачать: CL | DM;

Вниз

Округление в Firebird   Найти похожие ветки 

 
Juice ©   (2006-10-20 12:29) [0]

Нужно округлять Numeric-значения до второго знака после запятой. В UDF такого не нашел, может плохо искал. Как быть?


 
Johnmen ©   (2006-10-20 12:32) [1]

Где округлять? И для чего?


 
Juice ©   (2006-10-20 12:39) [2]

Сори, в хранимке. В голову приходит взять Numeric-переменную, умножить ее на 100 и присвоить Integer-переменной, затем поделить последнюю на 100 и присвоить обратно Numeric-переменной. Как думете, прокатит такое? Или есть что-то получше? Не на чем сейчас проверить.


 
Megabyte ©   (2006-10-20 12:41) [3]

Эээ, а разве не проще задать размерность Numeric до второго знака после запятой?


 
Johnmen ©   (2006-10-20 12:43) [4]

Прокатит.
Не забыть, что при приведении к типу интегер происходит арифметичекое округление.


 
Juice ©   (2006-10-20 12:52) [5]


> Эээ, а разве не проще задать размерность Numeric до второго
> знака после запятой?

Это был бы truncate


 
unknown ©   (2006-10-20 12:57) [6]


> Juice ©   (20.10.06 12:52) [5]
> Это был бы truncate

Нет.
select cast(12345.675 as numeric(15,2)) from rdb$database
Результат : 12345,68
select cast(12345.674 as numeric(15,2)) from rdb$database
Результат : 12345,67


 
Johnmen ©   (2006-10-20 13:24) [7]


> unknown ©   (20.10.06 12:57) [6]


Для 1 диалекта это не так.


 
unknown ©   (2006-10-20 13:33) [8]


> Johnmen ©   (20.10.06 13:24) [7]
> > unknown ©   (20.10.06 12:57) [6]
> Для 1 диалекта это не так.

Не совсем - есть небольшая разница в округлении, т.е. 12345.675 округляет вниз
до .67, а 12345.676 уже вверх  - до .68


 
Johnmen ©   (2006-10-20 13:48) [9]


> unknown ©   (20.10.06 13:33) [8]
> Не совсем -


Прошу прощения, что "не совсем"?

>есть небольшая разница в округлении, т.е. 12345.675 округляет вниз
>до .67, а 12345.676 уже вверх  - до .68

Разница, она либо есть, либо нет. И в 1 диалекте округление аболютно нормально. Вот только эффект разный.
Для размышлений попробуй, например, 32.325 округлить...:)))


 
Johnmen ©   (2006-10-20 14:00) [10]


> unknown ©


Совсем забыл, ещё попробуй округлить unknown ©   (20.10.06 12:57) [6], но приведением к numeric(9,2), 1 диал.
Это для полноты исходного материала для размышлений...:))


 
unknown ©   (2006-10-20 14:10) [11]


> Johnmen ©   (20.10.06 14:00) [10]

Признаю, был неправ. В 1-м диалекте в отличии от 3 обязательно будет
погрешность при округлении из-за специфики хранения значений :)


 
Johnmen ©   (2006-10-20 15:32) [12]


> unknown ©   (20.10.06 14:10) [11]


Да. Но не только "хранение", но и представление. О чём говорит результат
select cast(12345.675 as numeric(15,2)) from rdb$database
и
select cast(32.325 as numeric(15,2)) from rdb$database



Страницы: 1 вся ветка

Текущий архив: 2006.12.31;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.031 c
2-1165930015
oleglu
2006-12-12 16:26
2006.12.31
DBGrid


15-1165496533
Фёдр_иваныч
2006-12-07 16:02
2006.12.31
Готика 3


15-1166058481
Бугага
2006-12-14 04:08
2006.12.31
«Черную дыру» поймали с поличным


15-1165767749
Kolan
2006-12-10 19:22
2006.12.31
Забавный скроллбар


8-1147104191
Dstr
2006-05-08 20:03
2006.12.31
Stream и звук