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

Вниз

Сохранение измененных посредством TQuery таблиц   Найти похожие ветки 

 
Роман Василенко ©   (2002-03-08 11:56) [0]

Добрый... день.

Ситуация такая:

На форме есть TQuery, TDataSource, TDBGrid, в общем, все, как обычно. С помощью TQuery выполняется какой-нибудь запрос DML, например "delete from...". Существует некоторое количество случаев, когда результаты подобных команд не сохраняются в таблице. Ну, например, программка обвалилась, или что еще...

Вопрос: существует ли твердый способ сохранить изменения в таблицу (вроде dbiSaveChanges) непосредственно сразу после употребления запроса? Если можно, подскажите способ, при условии, что:

1. Я не использую TDatabase, TSession.
2. При инициализации всем TQuery задается путь к каталогу с файлами БД в свойство DatabaseName
3. Я использую таблицы формата Paradox (если это принципиально)


 
dealing ©   (2002-03-14 11:35) [1]

Попробуй использовать TDataBase.
При любом изменении таблицы делай следующее:

try
DataBase1.StartTransaction; // Начало Транзакции //
Query1.Unprepare;
...
Query1.Prepare;
Query1.ExecSql;
DataBase1.Commit; // Подверждение результатов транзакции,
если все прошло успешно //
except
DataBase1.RollBack; // Отмена выполненной транзакции, недачное
завершение операции //
MessageDlg("Ошибка записи в базу", , mtInformation,[mbOk],0);
end;

Такая система транзакций работает безотказно, все изменения отражаются четко.


 
Роман Василенко ©   (2002-03-18 10:04) [2]

Спасибо.



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

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

Наверх




Память: 0.47 MB
Время: 0.009 c
14-22814
Alexander Vasjuk
2002-02-27 14:17
2002.04.08
Подключиться к 3Com хабу


1-22642
SKing
2002-03-26 13:42
2002.04.08
Опять - DeсimalSeparator???


1-22748
Shark2001
2002-03-27 09:54
2002.04.08
Событие OnClick для меню


1-22741
Lego
2002-03-26 07:44
2002.04.08
PageControl ... как сохранить динамически созданые RichEdit и текст из них?


6-22779
Андре
2002-01-23 11:20
2002.04.08
Socket Error