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

Вниз

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

 
byTural ©   (2003-08-10 14:49) [0]

Использую ADODataSet и ADOConnection.
При добавлении записи происходит след.

...
ADOConnection.BeginTrans;
//для записи на котором стоит курсор
ADODataSet.Edit;
ADODataSet.FieldByName("PLM_ADD_PAID").AsBoolean := True;
ADODataSet.Post;
...
//добавляю новую запись
ADODataSet.Last;
ADODataSet.Append;
...


При нажатии на кнопку сохранение

...
ADODataSet.Post;
ADOConnection.CommitTrans;
...


Но при отмене

ADODataSet.Cancel;
ADOConnection.RollbackTrans;


Grid показывает что поле "PLM_ADD_PAID" True хотя после обновления она становится False
Пока что при каждом таком случае сразу после RollbackTrans запускаю процедуру обновления но помоему это не совсем правильно. А когда кол-во записей будет много.
Уважаемые мастера, подскажите пожалуйста если какое-нибудь свойство или метод у этих компонент кот. сама сразу обновит данные только для одной строки.

P.S. SELECT-ом идет выборка сразу из двух таблиц.


 
AkaSaint ©   (2003-08-11 23:20) [1]

Чтобы обновить одну запись, используй метод ADODataSet.Recordset.Resync (см. MSDN, как с ним работать). И еще, хочу сказать, что транзакции должны быть как можно более короткими по времени, т.к. они съедают ресурсы и в большей или меньшей степени мешают другим пользователям. Насколько я знаю, никогда не делаются транзакции, ждущие для своего завершения нажатия кнопки пользователем.



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

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

Наверх




Память: 0.47 MB
Время: 0.018 c
1-10690
snake1977
2003-08-25 11:47
2003.09.04
TEdit


3-10606
Malyatko
2003-08-13 17:07
2003.09.04
Подключение к базе данных.


1-10682
ossa
2003-08-21 09:59
2003.09.04
есть ли аналог TOpenDialog , но только для выбора папки?


3-10568
gsm
2003-08-10 21:33
2003.09.04
Вытаскивание blob-а из Оракла


8-10840
zumo
2003-05-08 06:41
2003.09.04
DSPAck