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

Вниз

Как правильно управлять явной транзакцией?   Найти похожие ветки 

 
Ruslan_   (2003-03-08 20:13) [0]

Как правильно управлять явной транзакцией, используя компоненты INTERBASE?
Я делаю так:
Data.IBQuery1.Transaction.StartTransaction;
try
……………………
……………………
……………………
Data.IBTransaction.Commit;
except
Data.IBTransaction.Rollback;
end;

при попытке внести изменение выходит сообщение: Transaction is active.
Я так понял что транзакция включается сразу после запуска программы и при попытке открыть транзакцию, пишет что транзакция уже открыта…
Объясните пожалуйста как правильно организовать явную транзакцию используя компоненты:
IBDatabase
IBTransaction
IBQuery

Заранее спасибо!


 
Johnmen ©   (2003-03-08 22:51) [1]

Перед выполнением любого (!) запроса неявно стартует транзакция. Чтобы этого избежать, стартуй транзакцию явно.
В твоем случае на момент явного старта уже был выполнен какой-либо запрос, а значит и стартована тр-ия...


 
Pat ©   (2003-03-09 01:41) [2]

if IBTransaction1.InTransaction then IBTransaction1.Commit;
IBTransaction1.StartTransaction;
Где-то примерно так...


 
Sergey Masloff   (2003-03-09 09:10) [3]

Pat © (09.03.03 01:41)
>if IBTransaction1.InTransaction then IBTransaction1.Commit;
>IBTransaction1.StartTransaction;

ИМХО лучше так:
var
OwnTrn : Boolean;
OwnTrn := True;
if IBTransaction1.InTransaction then
OwnTrn := False
else
IBTransaction1.StartTransaction;
try
DoSomething...
if OwnTrn then
IBTransaction1.Commit();
except
IBTransaction1.Rollback();
Raise;
end;




 
stranger71   (2003-03-11 10:57) [4]

Pat © (09.03.03 01:41)
>if IBTransaction1.InTransaction then IBTransaction1.Commit;
>IBTransaction1.StartTransaction;

Я сталкивался с такой проблемой, и это решение не помогло... Есть ли механизмы, ЗАПРЕЩАЮЩИЕ неявный старт транзакции?


 
Johnmen ©   (2003-03-11 11:06) [5]

Есть ! Этот механизм - явный старт...



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

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

Наверх




Память: 0.47 MB
Время: 0.02 c
4-88293
Pavel_Next
2003-01-30 12:32
2003.03.27
WinAPI


3-87878
ddenisv
2003-03-11 13:24
2003.03.27
DBGridEh - как делать следующее?


9-87770
delpher
2002-06-17 23:14
2003.03.27
GLScene - самые азы


3-87859
Павел
2003-03-01 05:03
2003.03.27
Нужные ресурсы


1-87978
TY
2003-03-18 06:49
2003.03.27
Вопросы связанные с датой и временем.