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

Вниз

поле NUMERIC(15, 5) не работатет с 5-ым знаком после запятой   Найти похожие ветки 

 
Михаил   (2003-11-06 10:06) [0]

Здраствуйте, мастера! База была написанна давно и работала около 2-х лет, но в связи с тем, что после зяпятой всегда было только 4 знака никто проблемы не замечал. После попытки записать в это поле число с пятью знаками после запятой, это число округлилось до четвертого знака...
InterBase 5.6 через BDE, enebled BCD=true
Хочется все исправить с наименьшими потерями...


 
Silver Alex ©   (2003-11-06 10:19) [1]

подробнее напиши, какими компонентами пользуешься (TAdoDataSet или TQuery), и тип этого поля(или параметра) в Delphi, если TBDCField то поробуй изменить его на TFloatField
напишешь что получилось :))


 
Johnmen ©   (2003-11-06 10:31) [2]

>После попытки записать ...

Как это делается ?

>число округлилось до четвертого знака

Это одна только видимость...:)


 
Михаил   (2003-11-06 10:42) [3]

использую TQuery... но думаю проблема тут совсем не в Delphi (пока), а в самом IB и BDE, т.к. данные округяются даже при непосредственном вводе из SQL explorer
при установки enebled BCD в false все знаки после запятой записываются, но боюсь что из-за этого попроут другие косяки с округлениями.


 
Silver Alex ©   (2003-11-06 10:50) [4]

все дело в BCD , у меня такая проблема была на MS SQL сервере.
Поменял тип параметра, попустило. Ну а с округлениями, так это классическая задача, вариантов немеряно :))


 
Romkin ©   (2003-11-06 10:54) [5]

Косяки у тебя прут, когда BCD включено. Сам попробуй
select cast(2/3 as numeric(15,2)) from rdb$database
из WISQL и в SQL explorer у которого Enable BCD=TRUE
Разницу чувствуешь?


 
Михаил   (2003-11-06 11:37) [6]

Romkin ©, при Enable BCD=TRUE
select cast(2/3 as numeric(15, 4)) дает 0,6666
а select cast(2/3 as numeric(15, 5)) дает 0,6667
фантастика! С чем это связано?
Проблема в том, что с этой базой работает не одна программа и не только моя. Боюсь что смена значения Enable BCD с TRUE на FALSE повлечет за собой переписывание кода. С меньшими затратами никак?


 
Romkin ©   (2003-11-06 11:46) [7]

Связано с неявным представлением в виде currency, а там точность 4 цифры. НАсчет других программ - в параметрах TDatabase можно прописать ENABLE BCD=TRUE (без лишних пробелов), перекроешь параметр в алиасе



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

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

Наверх




Память: 0.48 MB
Время: 0.02 c
4-90167
Serega____
2003-10-03 14:32
2003.11.27
API


1-89910
hellmachine
2003-11-15 04:23
2003.11.27
Возможно ли программно определить - был ли перекрыт виртуальный


6-90050
Beglec
2003-09-30 00:05
2003.11.27
Ошибка при передаче файла


3-89773
stud
2003-11-06 17:47
2003.11.27
отчеты........


1-89908
olookin
2003-11-14 21:59
2003.11.27
Пожалуйста гляньте - есть тут ошибка?