Главная страница
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.019 c
1-67267
$Hic0
2003-04-11 12:19
2003.04.21
byte2bin


3-67091
АндрейБ
2003-03-31 15:39
2003.04.21
БД Paradox


1-67383
Гость
2003-04-10 12:08
2003.04.21
Число строк в Memo1


1-67203
Den
2003-04-10 06:57
2003.04.21
Как считать любой ini-файл?


6-67433
Maestro1
2003-02-27 10:48
2003.04.21
Доступ к серверу удаленного доступа с помощью модема