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

Вниз

Could not convert variant of type (Null) into type (String)   Найти похожие ветки 

 
Lexa   (2005-06-08 21:41) [0]

Имеется ADOConnection, связанная с ним ADOTable, с которой связана DataSource, на которую ссылается DBGrid. После выполнения
ADOConnection.open();
ADOTable.open;
во второрой строке возникает ошибка "Project XXXX.exe raised exception class EVariantTypeCastError with message "Could not convert variant of type (Null) into type (String)". Process stoped". Причем после нажатия на F9 работа продолжается вполне нормально, DBGrid правильно отображает необходимые данные. В чем может быть дело???


 
ANB ©   (2005-06-08 22:58) [1]

Чего то ты намутил с настройками. Либо строки коннекта, либо в настройках поля. Кстати, а БД какая ? Я только что над ораклом поизгалялся твоим способом - ну не ругается на Null.


 
Anatoly Podgoretsky ©   (2005-06-08 23:08) [2]

Да у него напутано в программе.


 
ЮЮ ©   (2005-06-09 05:25) [3]

>Причем после нажатия на F9 работа продолжается вполне нормально

Следует нажимать F8(F7) чтобы оставаться в коде обработчмка, где возникло исключение или посмотреть стэк вызовов. Другими словами, отлаживать программу надо.

С другой стороны, если приложение не упало, значит есть обработка try ... except. Если в твоем коде, то можно избежать лишнего exception, если в глубинах VCL - смириться


 
Lexa   (2005-06-09 10:29) [4]

У меня бд Access. Что я что то с настройками напутал я и сам понимаю, а какие именно настройки? Приследуется цель чтения некоторых таблиц из БД, если для этого можно обойтись меньшим числом компонентов, то подскажите , пожалуйста, как. При отладке по F7 ошибка возникает в строке ADOTable.open, значит напутал именно в его свойствах.

>С другой стороны, если приложение не упало, значит есть >обработка try ... except

Такой обработки в тексте программы нет.


 
bon ©   (2005-06-09 13:05) [5]

А чем показуешь DataSource?


 
Плохиш ©   (2005-06-09 13:16) [6]

>Lexa   (09.06.05 10:29) [4]

Для чтения значений текстовых полей используй явное преобразование .AsString


 
Lexa   (2005-06-09 13:24) [7]

>Плохиш
А где его использовать? Там же всё на автомате, установлены связи и всё.


 
Lexa   (2005-06-09 13:33) [8]

Попробовал использовать для таблицы, где все данные числовые, ошибка всёравно возникает.


 
КиТаЯц ©   (2005-06-09 14:00) [9]

>Плохиш ©   (09.06.05 13:16) [6]
Да.

Или:
Edit1.text:= VarToStr(...)


 
Плохиш ©   (2005-06-09 14:10) [10]

>Lexa   (09.06.05 13:24) [7]
>Там же всё на автомате, установлены связи и всё.


Где "всё на автомате" таких проблем не возникает. Т.ч. врёшь.


 
Anatoly Podgoretsky ©   (2005-06-09 14:33) [11]

Плохиш ©   (09.06.05 14:10) [10]
Не т.ч, а т.е.


 
Lexa   (2005-06-09 15:56) [12]

Итак, в подробностях:
Имеется форма, на ней ADOTable1, в свойствах которого прописана ConnectionString, указана таблица в базе, которую нужно читать. Затем имеется DataSource1 в свойствах которого параметр DataSet определён как ADOTable1. Так-же имеется DBGrid в свойстве которого DataSource прописано DataSource1. Имеется процедура procedure TfrmMain.FormCreate(Sender: TObject);
begin
 ADOTable1.Open;
end;

После запуска программы получаем вышеупомянутое сообщение. После повторного нажатия F9 программа продолжает работу, и DBGrid верно отображает необходимые данные. Если это не "всё на автьомате", то извините.


 
Anatoly Podgoretsky ©   (2005-06-09 16:13) [13]

Lexa   (09.06.05 15:56) [12]
Теперь тоже самое, но в отдельном проекте.


 
Lexa   (2005-06-12 21:54) [14]

И всё же в чем может быть дело?? Киньте хотябы ссылочку на пример или толковую статью по работе с базами Access через ADO в Delphi.


 
alares   (2005-06-16 11:31) [15]

Lexa, та же беда :( только я к dbf подключаюсь. Если сделать так:

 try
   ADOConnection.Open;
   ADOTable.Open;
 except
   on EVariantTypeCastError do;

- все работает.



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

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

Наверх




Память: 0.5 MB
Время: 0.049 c
3-1119714262
ali_tash
2005-06-25 19:44
2005.07.31
TDBLookupComboBoxEh


14-1120815627
Macrodens
2005-07-08 13:40
2005.07.31
Кто знает, где можно скачать


1-1121065795
Курдль
2005-07-11 11:09
2005.07.31
Про отображение BLOB типа jpeg в DBImage


3-1118917400
ivc_andr
2005-06-16 14:23
2005.07.31
Узнать текст запроса и Host


1-1121297550
JohnSmith
2005-07-14 03:32
2005.07.31
Как создать динамический массив потоков ?