Главная страница
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.036 c
1-89992
AnSo
2003-11-10 20:17
2003.11.27
TForm.Print


3-89771
Евгений Т.
2003-11-06 12:58
2003.11.27
Запись в dbf-таблицу БД на ACCESS


7-90139
Basil
2003-09-08 18:08
2003.11.27
Помогите спрятать прогу от CTRL+ALT+DEL в NT!


1-89903
limk
2003-11-14 17:28
2003.11.27
memo


4-90156
bolegator
2003-10-05 12:18
2003.11.27
Wheel2Key