Главная страница
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.028 c
3-1161057847
DelphiN!
2006-10-17 08:04
2006.12.31
Помогите написать SQL запрос ...


15-1165867511
Handle
2006-12-11 23:05
2006.12.31
TrayBar


15-1165397874
DevilDevil
2006-12-06 12:37
2006.12.31
Как правильно снимать контактные линзы?


3-1161036521
БогданБ
2006-10-17 02:08
2006.12.31
Как указатель строки DBGridEh SQL запроса сопоставить с базой.


15-1165264946
yevgeniy
2006-12-04 23:42
2006.12.31
печать сразу 2 файлов на 1 листе?