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

Вниз

ADO и поставщики данных   Найти похожие ветки 

 
Nous Mellon ©   (2004-03-29 11:07) [0]

Доброго времени суток, господа.
Возникла такая проблема:
Есть некая mdb База в которой наличивсвуют несколько таблиц.
Заполняются они в run-time ( используется компонент ADOTable )
В одной из-них четыре поля: три целочисленных и последнее действительное.
Я делал Insert записи, заполнял данные поля и в конце делал Table.post;
В качестве поставщика данных для объекта Connection использовался Jet.
При выполнении Post вылетает ошибка несоответсвия типов данных.
Причем если закомментировать заполнение действительного поля то все нормально.
Если открыть БД в Аксесс то видно что в качестве разделителя целой части в Бд используется  ",", а в Делфи ".". Может быть в этом проблема? Но если сменит Jet на стандартный MSDASQL то все почему-то работает.
Может быть вы подскажете с чем связана эта ошибка и пути ее возможного разрешения без смены Jet.


 
sniknik ©   (2004-03-29 11:24) [1]

> Может быть вы подскажете с чем связана эта ошибка и пути ее возможного разрешения без смены Jet.
вот с этим
> Я делал Insert записи, заполнял данные поля и в конце делал Table.post;
, заполнять по другому.


 
Nous Mellon ©   (2004-03-29 14:24) [2]


> , заполнять по другому.

как правильно заполнять используя Jet?
Если можно небольшой пример


 
Cobalt ©   (2004-03-29 14:28) [3]

а как вы заполняли?
Примерчик, пожалуйста.


 
Nous Mellon ©   (2004-03-29 14:41) [4]


> а как вы заполняли?

если вы ко мне то пожалуйста
MyTableMyFloatField.Value := MyFloatVar;
MyTable.Post;
Идентификаторы конечно были не такие но смысл тот.


 
Nous Mellon ©   (2004-03-29 14:42) [5]

Сорри забыл первую строку
MyTable.Insert;


 
Cobalt ©   (2004-03-29 14:59) [6]

2 Nous Mellon ©
рекомендую делать так:
MyTable.FieldByName("Name").AsFloat:=MyFloatVar;


 
Nous Mellon ©   (2004-03-29 15:03) [7]


> рекомендую делать так:
> MyTable.FieldByName("Name").AsFloat:=MyFloatVar;

Спасибо, попробую может спасет :)


 
Nous Mellon ©   (2004-03-29 15:08) [8]

нет, к сожалению результат тот же...
Может еще какие-нибудь предложения?


 
sniknik ©   (2004-03-29 15:23) [9]

var MyFloatVar: double; ?


 
Nous Mellon ©   (2004-03-29 15:32) [10]


> var MyFloatVar: double; ?

Сейчас попробовал и Double и Real - результат тот эе...
А вообще был Real


 
sniknik ©   (2004-03-29 15:36) [11]

тогда значит поле в таьлице всетаки не того типа, либо ты всетаки делал не так как тебе говорили.
не
MyTable.FieldByName("FloatName").AsFloat:=MyFloatVar;
к примеру, а
MyTableMyFloatField.AsFloat:= MyFloatVar;


 
Nous Mellon ©   (2004-03-29 15:48) [12]

Кажется я разрешил проблему заменой типа данных самого поля.
Он был "Действительное" и я не знал какой в Делфи точно ему эквивалент(думал что Реал),я поменял на "Двойное", а переменную поставил Double и вроже бы заработало. Спасибо всем, в частности sniknik, который уже в
н-ный раз меня выручает.



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

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

Наверх




Память: 0.49 MB
Время: 0.029 c
14-1080991331
VID
2004-04-03 15:22
2004.04.25
Имея 1 гиг ОЗУ как лучше всего поступить со свопом винды ?


14-1080814771
химик
2004-04-01 14:19
2004.04.25
Рихтер дайте пож, ссылку где скачать можно


7-1077170724
mxsb
2004-02-19 09:05
2004.04.25
Как увидеть обмен другой проги с Com-порт ом


3-1080713015
СлБ
2004-03-31 10:03
2004.04.25
Выделение в тексте


1-1081118674
Alex79
2004-04-05 02:44
2004.04.25
Проблема смены шрифтов