Форум: "Базы";
Текущий архив: 2003.04.21;
Скачать: [xml.tar.bz2];
Вниз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;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.01 c