Показать сообщение отдельно
  #1  
Старый 18.11.2010, 12:02
p.majorov p.majorov вне форума
Прохожий
 
Регистрация: 18.11.2010
Сообщения: 1
Репутация: 10
По умолчанию Проблема с редактированием записи таблицы

Доброго времени суток всем!

В общем начну по порядку:
СУБД InterBase, БД из 8 таблиц, в каждой по одному полю blob типа.

Для работы с базой использую компоненты dbExpress:
SQLConnection для связи с базой и компоненты SimpleDataSet для работы с таблицами.

Добавление записей и удаление происходит нормально. А вот с редактированием проблема, а именно:
При редактировании некоторых записей таблицы вылетает ошибка "SimpleDataSet: Must apply updates before refreshing data" - не проходит метод ApplyUpdates().

Кто сталкивался подскажите в чем проблема.

Кусок кода в котором и происходит ошибка
Код:
DataModule1.sidsAdmin.Edit;    //открываем запись на редактирование
  ... ...
DataModule1.sidsAdmin.FieldByName('data_sozd').AsDateTime:=StrToDate(Edit_date_admin.Text);
   DataModule1.sidsAdmin.FieldByName('nomer_doc').AsInteger:=StrToInt(Edit_No_admin.Text);
  ... ...
 try   //создаем поток для blob
     stream_db:=DataModule1.sidsAdmin.CreateBlobStream     (DataModule1.sidsAdmin.FieldByName('PICTURE'),bmWrite);
      file_stream:=TFileStream.Create(Edit_pdf_add.Text,fmOpenRead);
      stream_db.CopyFrom(file_stream,file_stream.Size);
      finally
      file_stream.Free;
      stream_db.Free;
      end; 
   end;
   DataModule1.sidsAdmin.Post;
   DataModule1.sidsAdmin.ApplyUpdates(0);
   DataModule1.sidsAdmin.Refresh;
Ответить с цитированием