Обработка ошибок

Слайд 2

TRY/CATCH Ошибки с уровнем серьезности больше 10 и меньше 20 в

TRY/CATCH

Ошибки с уровнем серьезности больше 10 и меньше 20 в блоке

TRY приводят к передаче управления блоку CATCH.
Ошибки с уровнем серьезности 20 и больше, которые не закрывают соединения, также обрабатываются блоком CATCH.
Ошибки компиляции и некоторые ошибки выполнения программы, задействующие компиляцию уровня инструкции, прерывают выполнение пакета немедленно и не передают управление CATCH.
Если ошибка произошла в блоке CATCH, транзакция прерывается и ошибка возвращается вызывающему приложению, если блок CATCH не вложен в блок TRY.
В блоке CATCH можно выполнить фиксацию или откат текущей транзакции, если транзакция не может быть зафиксирована и ее необходимо откатить. Для проверки состояния транзакции можно запросить функцию XACT_STATE.
Слайд 3

Функции CATCH ERROR_NUMBER — возвращает номер ошибки; ERROR_MESSAGE — возвращает сообщение

Функции CATCH

ERROR_NUMBER — возвращает номер ошибки;
ERROR_MESSAGE — возвращает сообщение об

ошибке;
ERROR_SEVERITY — возвращает уровень серьезности ошибки;
ERROR_LINE — возвращает номер строки в пакете, где произошла ошибка;
ERROR_PROCEDURE — имя функции, триггера или процедуры, которые выполнялись в момент возникновения ошибки;
ERROR_STATE — состояние ошибки
Слайд 4

Сообщения об ошибке в SQL Server Номер ошибки (error number) Уровень

Сообщения об ошибке в SQL Server

Номер ошибки (error number)

Уровень серьезности (Severity level).
Состояние (state)
Сообщение об ошибке (error message)
sys.messages – содержит сообщения
Слайд 5

Команда RAISERROR RAISERROR ( { msg_id | msg_str | @local_variable }

Команда RAISERROR

RAISERROR ( { msg_id | msg_str | @local_variable

}
{ , severity , state }
[ , argument [ ,...n ] ] )
[ WITH option [ ,...n ] ]
RAISERROR ('Error in usp_InsertCategories stored procedure', 16, 0);
RAISERROR ('Error in %s stored procedure', 16, 0, N'usp_InsertCategories');
DECLARE @message AS NVARCHAR(1000) = 'Error in %s stored procedure';
RAISERROR (@message, 16, 0, N'usp_InsertCategories');