Главная страница
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.017 c
3-10571
PsoFT
2003-08-14 13:42
2003.09.04
excel


7-10999
tan
2003-06-20 10:22
2003.09.04
считывание с COM-порта с помощью int14?


14-10952
Ig
2003-08-13 20:36
2003.09.04
Ни кто не встречал компонент для Delphi


11-10665
LITTEL[MF]
2002-12-29 02:30
2003.09.04
Программирование в KOL(MCK)


14-10962
Е-Моё имя
2003-08-15 18:19
2003.09.04
Как бы рассказали