Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 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.47 MB
Время: 0.016 c
14-55721
Marser
2003-06-30 22:20
2003.07.17
---|Ветка была без названия|---


11-55486
Avenger__
2002-11-09 14:08
2003.07.17
ListView and WinXp


7-55877
Карелин Артем
2003-04-28 13:34
2003.07.17
Сервис для W2000. Восстановление при сбое.


3-55403
Sceptik
2003-06-23 15:31
2003.07.17
Как вывести данные ч з DBComboBox


3-55461
Belocarsk
2003-06-25 12:27
2003.07.17
Маркер сортировки в столбце DBGrida как Outlooke