Форум: "Базы";
Текущий архив: 2003.09.04;
Скачать: [xml.tar.bz2];
ВнизКак обновить данные после отмены транзакции Найти похожие ветки
← →
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;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.011 c