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

Слайд 2

TRY/CATCH

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

TRY/CATCH Ошибки с уровнем серьезности больше 10 и меньше 20 в блоке
приводят к передаче управления блоку 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');