Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.02.29;
Скачать: [xml.tar.bz2];

Вниз

Назавершенная транзакция в прерванной хп.   Найти похожие ветки 

 
Bless   (2004-02-03 16:44) [0]

Что происходит, выполнение хранимой процедуры, внутри которой была начата транзакция (begin tran...), была прервана из-за ошибки до команды commit tran или rollback tran.
Что происходит с транзакцией в таком случае? Откатывается ли она автоматически?
Или ошибки внутри процедуры не прерывают ее работу?


 
KSergey   (2004-02-03 16:45) [1]

Нифига она не откатывается
Это надо учитывать при разработке ХП и откатывать ее обязательно!


 
KSergey   (2004-02-03 16:47) [2]

Ошибки внутри процедуры не завершают ее работу
после каждого оператора надо писать

IF @@ERROR <> 0
BEGIN
ROLLBACK TRANSACTION
RETURN 0 -- признак ошибки
END


или ждать юкон - в нем обещают нормальную обработку исключений


 
Nikolay M.   (2004-02-03 17:04) [3]

Скорее всего не откатится. А какого рода "ошибки" имеются в виду?


 
Bless   (2004-02-03 17:27) [4]

to KSergey> Спасибо.

>А какого рода "ошибки" имеются в виду?

Не знаю. Разные. А что, это имеет значение?


 
ZrenBy   (2004-02-03 18:14) [5]

SET XACT_ABORT ON

Но ложка дегтя
http://www.sql.ru/forum/actualthread.aspx?bid=1&tid=39919


 
Bless   (2004-02-04 09:39) [6]

ZrenBy> Вот это здорово :(
Тамошним примером навеяло такие вопросы:
1) Когда компилируется хп?
Перед ее вызовом?
Или один раз сразу после ее создания?


 
Nikolay M.   (2004-02-04 09:57) [7]


> Когда компилируется хп?

Насколько я понимаю в колбасных обрезках, то если в ХП имеется динамический SQL, то ХП будет компилиться каждый раз перед вызовом. Если такого нет, то при создании.
Буду рад услышать другие аргументированные мнения.


 
Nikolay M.   (2004-02-04 10:18) [8]


> Если такого нет, то при создании

Поправлю сам себя. Вот тут описаны некоторые подводные камни:
http://mylib.noda.ru/view.php?id=475


 
Bless   (2004-02-04 14:40) [9]

Всем спасибо. Вопрос исчерпан.



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

Форум: "Базы";
Текущий архив: 2004.02.29;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.01 c
1-93850
Aleks-U
2004-02-16 17:35
2004.02.29
Пропажа курсора


14-94113
ИМХО
2004-02-09 00:39
2004.02.29
Абрамович заарканил Роналдо и Роберто Карлоса


1-93948
morev_s_a
2004-02-17 18:19
2004.02.29
Как напечатать несколько графиков на одной странице?


1-93975
SHS
2004-02-17 09:27
2004.02.29
Сортировка строк


14-94127
SiJack
2004-02-06 15:01
2004.02.29
Может кто подскажет какой грид взять чтобы в нем следующее мона





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский