Главная страница
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-67344
Андреев Павел
2003-04-09 13:27
2003.04.21
Создание формы в dll


14-67494
Delpher_Gray
2003-04-03 15:02
2003.04.21
Не могу решить проблему...


4-67608
max2057
2003-02-20 12:59
2003.04.21
DeviceIoControl и CDROM


1-67300
ST
2003-04-11 00:19
2003.04.21
shellexecute


1-67374
Laxer
2003-04-09 10:42
2003.04.21
Вертикальный текст в QReport