Текущий архив: 2003.07.17;
Скачать: CL | DM;
ВнизApplyUpdates? Найти похожие ветки
← →
AlexA (2003-06-11 12:53) [0]Имееться два IBQuery + IBUpdateSql (IBQuery1, IBQuery2)
Оба висят на одной транзакции Tr1. Для обоих CachedUpdatesb = True
Для таблицы из которой берет данные первый IBQuery, имется триггер (BEFORE INSERT) , который проверяет заполнение обязательный полей, в случае
отсутствия данных, вызываеться исключение.
В програме происходит следующее
1.Старт транзакции
2. Вставка данных в оба запроса (в первом запросе отсутствуют обезательные поле)
3. Try
DM.IBQuery1.ApplyUpdates; //при отладке после этого выскакивает сообщение о ошибке, далее ни какие операторы не выполняються, Для второго Query данные сохраняються .
DM.IBQuery2.ApplyUpdates;
DM.IBTr1.Commit;
except
ShowMessage("Ошибка");
exit;
end;
При работе (не отладка) сообщение о ошибке не возникает.
Почему не выполняються оператору следующие ниже? Как сохраняються данные для втрого Query?
Вообще по задумке необходимо, выдать сообщение о ошибке ( нашел как это делаеться - например событие PostError) и главное дать возможность пользователю отредактировать данные.
Но такое впечатление складываеться, что происходит потверждение транзакции и все приплыли..
← →
Жук (2003-06-11 13:40) [1]Чё-то не очень понятно.
← →
AlexA (2003-06-12 01:16) [2]>Жук Имеется код, вносяться даные, на сервере IB проверяюся в триггере, данные ошибочные, вызываеться исключение. Но для другого НД( относяшихся к той же транзакции ) происходит запись в БД. Почему? КАК ИЗБЕЖАТЬ?
← →
kostik78ua (2003-06-12 09:22) [3]1. Обрати внимание на параметр (var Action: TDataAction) в OnPostError.
2. Не забывай в случае ошибки делать RollBack
3. Лучше вместо IBQuery1.ApplyUpdates; делать IBDatabase1.ApplyUpdates([IBQuery1]);
← →
AlexA (2003-06-14 03:55) [4]>kostik78ua Не хочу делать RollBack, хочу пользователю дать возможность исправиться... :-)
← →
AlexA (2003-06-25 16:14) [5]Посоветуйте....
Страницы: 1 вся ветка
Текущий архив: 2003.07.17;
Скачать: CL | DM;
Память: 0.45 MB
Время: 0.009 c