Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #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;
Ответить с цитированием
  #2  
Старый 18.11.2010, 13:19
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Мне одному кажется странным выбор компонентов для IB?
Вы же сами указали, что не проходит ApplyUpdate. Т.е. скорее всего какие- то новые данные не проходят ограничения базы. Поставьте в OnReconcicleError:
Код:
ShowMessage(E.Message);
и тогда узнаете почему не проходит Apply
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 17:23.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025