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

Вниз

VIEW в БД и в Дельфи   Найти похожие ветки 

 
ELENA_P ©   (2006-01-19 13:47) [0]

Привет всем! Ситуация такая: в БД в таблице поля Numeric(15.5), строго обязательно иметь 5 знаков после дес.точки. В БД есть VIEW, который использует это поле. Работа с таблицей (insert, update) происходит правильно как ручками в БД, так и через датасеты в Дельфи, т.е. правильно вставляется значение, например, 1.89111. В этом VIEW данные тоже в БД отбражаются правильно, с 5-ю знаками. В программе отображение этого поля N(15.5) в датасетах, опирающихся на таблицу, правильно, так же вижу 5 знаков. При этом в модуле данных есть датасет, который основан на упомянутом выше VIEW. Вот тут и проблема: в гриде, где этот VIEW выводится, значение 1.89110, т.е последняя цифра отбрасывается. Что ни делала - пятый знак отбрасывает . Поставила display format как в датасете, так и в гриде такой, как надо.
В модуле данных поле интерпретируется так: viewTARIFY_VIEWZNACHENIE: TFIBBCDField
Что еще можно сделать, в чем причина проблемы?


 
Johnmen ©   (2006-01-19 13:52) [1]

Должно, по идее, интерпр. как TFIBFloatField.
Какой, кстати, диалект?


 
ELENA_P ©   (2006-01-19 14:12) [2]

Диалект 3. Все другие поля Numeric - как Float, правда, там всего 2 знака после точки. До этого все поля, которые теперь 15.5, были 15.4. Даже не возникало никаких проблем. Пробовала еще поменять эти 15.5. в БД на DOUBLE PRECISION (соответственно, перестроила VIEW b обновила все поля в модуле данных, т.е. удалила и заново добавила), но интерпретация поля осталась та же и сообщение об ошибке, мол, требуется BCD, а актуально Float.


 
Johnmen ©   (2006-01-19 14:20) [3]

Вот из TFIBBCDField+F1
Because TFIBBCDField uses the Currency type to work with data from BCD fields, TFIBBCDField limits the precision of the BCD values it can support to 4 decimal places and 20 significant digits.
Также к прочтению рекомендуется Language Reference раздел Datatypes.


 
ELENA_P ©   (2006-01-19 14:27) [4]

Это я читала, так непонятно, почему возник этот тип BCD,  а не Float? Почему так интерпретируется? В БД ведь Numeric


 
Johnmen ©   (2006-01-19 14:36) [5]

Также к прочтению рекомендуется Language Reference раздел Datatypes.
:)

Удалить экземпляр компонента, имеющий указанный тип поля. Завести его заново.
Посмотреть тип во вновь заведённом...



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

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

Наверх




Память: 0.48 MB
Время: 0.054 c
2-1140364943
Yaffil
2006-02-19 19:02
2006.03.12
SQL: Как узнать содержимое конкретной ячейки?


2-1140593231
Рафик
2006-02-22 10:27
2006.03.12
Memo


1-1139390282
nastya
2006-02-08 12:18
2006.03.12
вставить нестандартный символ


8-1128233186
homm
2005-10-02 10:06
2006.03.12
16 битное значение цвета из 32 битного представления


15-1140416697
Rentgen
2006-02-20 09:24
2006.03.12
Ссылка-чекбокс не работает в IE