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

Вниз

Explicit Transactions в хранимых процедурах.   Найти похожие ветки 

 
ЛешаК   (2003-04-03 06:58) [0]

Здравствуйте.
Прошу консультации в вопросе с явными тразакциями в хранимых процедурах.
Пример чати кода хранимой процедуры.
BEGIN TRAN
INSERT INTO ..... //операция выполняется
INSERT INTO ..... //операция выполняется
INSERT INTO ..... //опрерация невыполнятеся
COMMIT TRAN
В результате получаю, что хотя и последняя операция в транзакции невыполняется, но результаты первых двух заносятся в базу. Если же надо точно писать ROLLBACK или COMMIT, то как узнать результат выполения транзакции.


 
ЮЮ ©   (2003-04-03 08:27) [1]

A разве у тебя есть какая-то проверка на результат INSERT?
Это не Дельфи, здесь никаких Exeption-ов не возникает при ошибке в INSERT и COMMIT TRAN безусловно выполнится


 
Z_man7777 ©   (2003-04-03 08:55) [2]

!ЮЮ!
А как можно откатить транзакцию, если произошла ошибка или что-нибудь вроде такого?


 
jocko ©   (2003-04-03 09:18) [3]

DECLARE @ERR int
BEGIN TRAN
--некоторые действия
***********************
IF @@ERROR <> 0 SET @ERR = @@ERROR
--некоторые действия
***********************
IF @@ERROR <> 0 SET @ERR = @@ERROR
--некоторые действия
***********************
IF @@ERROR <> 0 SET @ERR = @@ERROR
IF @ERR = 0
BEGIN
COMMIT TRAN
RETURN (@ERR)
END
ELSE
BEGIN
ROLLBACK TRAN
RETURN (@ERR)
END



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

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

Наверх




Память: 0.47 MB
Время: 0.013 c
1-67264
Tsarik
2003-04-11 11:53
2003.04.21
Выравнивание в StringGrid


14-67459
Seldon
2003-04-05 21:34
2003.04.21
TextConv


3-67094
Fiend
2003-04-02 14:21
2003.04.21
кодировка в FireBird


1-67199
AlexanderSK
2003-04-10 13:45
2003.04.21
Сообщение об ошибке при работе с DCOM


1-67247
Wedos
2003-04-10 12:47
2003.04.21
Как сделать задержку