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

Вниз

Проблема с использованием BCD полей   Найти похожие ветки 

 
GAndrei   (2004-03-23 12:30) [0]

Уважаемые мастера , помогите пожалуйста решить такую проблему.

Доступ к базе организован через BDE
Включено свойство Enabled BCD
в базе существует поле numeric(10,6)

но при выполнени запроса прилетает число  точность которого 4
Возможно ли как то задатть в настройках BDE точность BCD полей?


 
GAndrei   (2004-03-24 12:47) [1]

нашел ссылочку http://www.rxlib.ru/faqs/faqd_en/17708.html
Здесь сказано что решением проблемы может быть использование FMTBCD полей. Но как их использовать непонятно. Если кто-то знает решение помогите пожалуйста


 
stas ©   (2004-03-24 13:43) [2]

А какая версия MSSQL ?


 
GAndrei   (2004-03-24 17:51) [3]

2000 sp3
но здесь проблема не с SQl Он то как раз очень акуратно работает

Я заметил такую особенность
В делфи нет чисел с фиксированой точкой, есть только тип float или Currency. Если запрос возвращает число с фиксированой точкой (Numeric), то делфа,BDE его интерпритирует как float (в случае если BCD отключено) или же как BCD (в этом случае точность не выше 4). Эта интерпритация приводит к "странному" результату
Например, в гриде вводится число 10.1 - оно тут же "превращается" в 10.0999.
Нашел такой вариант решения проблемы
Если на сервере хранится число с фиксированой точкой я выбираю это число таким образом: round(cast(Тable.Kurs as float),6,0) as Kurs
После этого проблемы исчезли.



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

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

Наверх




Память: 0.45 MB
Время: 0.032 c
1-1080892540
Серж
2004-04-02 11:55
2004.04.18
Макроподстановка кода(!) в Delphi?


8-1072856792
ИЛЕЙ
2003-12-31 10:46
2004.04.18
Ребят, помогайте с BASS.DLL


14-1080147088
Undert
2004-03-24 19:51
2004.04.18
Второпласт в бруске


14-1079876188
Undert
2004-03-21 16:36
2004.04.18
А куда делось


3-1079696178
int21h
2004-03-19 14:36
2004.04.18
Права в Paradox





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский