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

Вниз

Как от этого исбавиться - BOF или EOF имеет значение True ???   Найти похожие ветки 

 
Kardash   (2006-06-23 13:30) [0]

Народ подскажите пожалуйста что и где надо исправить.
Есть две формы и база(ACCESS) через ADOconnection. На первой форме DBGrid, в к-м соответственно отображаютя данные таблицы.На второй форме DBEditы. Есть поиск через filtered:

AdoTable1.Filter:="(fam="""+ Edit1.Text + """"+" )";
AdoTable1.Filtered:=true;

Вторая форма сделана для изменения данных таблицы.
Проблема в следующем: когда нахожу какое-то значение из таблицы (в Гриде оно становится единственным) и хочу его потом изменить мне выскакивает след. сообщение:

Project Project.exe raised exception class EOleException with message "BOF или EOF имеет значение True, либо текущая запись удалена. Для выполняемой операции требуется текущая запись".

Если поиск не включать, то всё заменяется нормально.

Вторая форма открывается сразу с form1.ADOTable1.Edit;
А на сохранении стоит form1.ADOTable1.Refresh;

В чём тут может быть проблема???


 
Desdechado ©   (2006-06-23 13:34) [1]

Поставить все Update"ы с сайта борланда.


 
Johnmen ©   (2006-06-23 13:35) [2]

Достаточно в строке поиска (над "показать мои вопросы") указать "BOF" и нажать кнопу "найти".


 
Kardash   (2006-06-23 14:06) [3]

Update"ы помогут? У меня подозрения, что я где-то, что-то не учёл.


 
Desdechado ©   (2006-06-23 15:58) [4]

> Есть поиск через filtered
Это называется "отбор нужного".
А поиск - это позиционирование на одном из нужных.


 
ЮЮ ©   (2006-06-24 06:00) [5]


> Вторая форма открывается сразу с form1.ADOTable1.Edit;
> А на сохранении стоит form1.ADOTable1.Refresh;


Вторая форма тоже редактирует form1.ADOTable1? Тогда зачем Refresh?
Ключевое поле в таблице есть? Refresh идет по ключевому полю?

При наличии хотя бы одного "нет" имеем нормальную реакцию:
form1.ADOTable1.Refresh пытается найти текущую запись в базе, а её такой уже нет


 
Kardash   (2006-06-24 16:24) [6]

Народ, я конечно не мастер, но походу действительно у меня тупит сама делфа. Потому как при запуске скомпилированного ехе-шника данные траблы исчезли. Я так понимаю мне надо 100% качать апдейты. Спасибо всем за ответы.


 
sniknik ©   (2006-06-24 16:41) [7]

> Потому как при запуске скомпилированного ехе-шника данные траблы исчезли.
ошибка времени исполнения у тебя "спрятана", в дизайне нет. т.е. например сделай новый проект, добавь кнопку. на нее код
procedure TForm1.Button1Click(Sender: TObject);
var
 i, j: double;
begin
 try
   i:= 0;
   j:= 100;
   ShowMessage(FloatToStr(j / i));
 except end;
end;

явная ошибка, но в защищеном блоке и без обработки т.е. "спрятана", при нажатии при выполнении из под дельфей ошибка все одно будет показываться, а при запуске екзешника нет. (отключить в дизайне это в "tools-debuger options-languige exceptions-stop on delphi exceptions" галку снять... но не советую... лучше пусть останется)



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

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

Наверх




Память: 0.48 MB
Время: 0.037 c
15-1154961344
worldmen
2006-08-07 18:35
2006.09.03
Создание каталога в DOS


2-1155583415
RASkov
2006-08-14 23:23
2006.09.03
В классе ссылка на класс


2-1155723451
Батыр
2006-08-16 14:17
2006.09.03
Отправка писем


3-1151323751
Sirus
2006-06-26 16:09
2006.09.03
Прямой доступ к DBF файлам в Delphi 2006


4-1147002915
Dstr
2006-05-07 15:55
2006.09.03
ApplicationEvents1Message