加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 云计算 > 正文

SQL Server异常代码处理的深入讲解

发布时间:2020-11-09 18:34:12 所属栏目:云计算 来源:网络整理
导读:这篇文章首要给各人先容了关于SQL Server非常代码处理赏罚的相干资料,文中通过示例代码先容的很是具体,对各人的进修可能事变具有必然的参考进修代价,必要的伴侣们

SQL Server行使TRY...CATCH 布局实现TSQL语句的错误处理赏罚,TRY呼吁认真监控语句执行的环境,假若有TSQL语句产生非常,而且严峻级别(Severity Level)大于10,而且小于20,那么CATCH呼吁会捕捉到非常的错误。

BEGIN TRY
   { sql_statement | statement_block }
END TRY
BEGIN CATCH
   [ { sql_statement | statement_block } ]
END CATCH

数据库开拓工程师必要把一条或多条语句写入到TRY代码块中,假如TRY代码块中的代码在执行进程中产生错误,那么在错误产生的点之后的代码不再执行,措施的节制权转移到CATCH代码块块中。假如TRY代码块没有产生错误,那么不会执行CATCH代码块,措施的节制权转移到END CATCH之后的语句。

留意,在CATCH代码块中捕捉的非常不会返回给挪用措施,假如必要把错误动静返回给挪用措施,必要在CATCH代码块中行使THROW(或RAISERROR,不保举行使)呼吁显式抛堕落误。

一,获取非常动静

在TSQL中,行使TRY和 CATCH编写非常处理赏罚代码块,在CATCH子句中,行使以下函数,可以或许获取非常产生时的信息。

--返回产生错误的代码行号(LineNumber)
ERROR_LINE ( )
--返回错误号(ErrorNumber)
ERROR_NUMBER ( )
@@ERROR
--返回错误动静(ErrorMessage)
ERROR_MESSAGE ( )
--返回产生错误的SP Name
ERROR_PROCEDURE ( )
--返回错误的严峻度(Error Severity)
ERROR_SEVERITY ( )
--返回错误的状态(Error State)
ERROR_STATE()

SQL Server抛出的一个错误,凡是包罗错误代码(Error Number)、严峻级别(Severity Level)、错误状态(Error State)和错误动静(Error Message)等信息。

1,错误代码

错误代码,可以由变量@@ERROR 和函数ERROR_NUMBER()得到,用于返回上一条语句的错误代码,该代码独一标识该错误。

2,错误的严峻级别

错误的严峻措施(Severity Level)共有24个级别,表白SQL Sever碰着题目的范例,Severity Level是一个int范例,可以由函数ERROR_SEVERITY() 返回,数值越大,声名题目越严峻。

凭证错误对体系的影响措施,把严峻级别分为四组:

0-10:信息,可以以为是warning

11-16:错误,是用户代码导致的

17-19:很是严峻的错误,只能由体系打点员来修复

20-24:致命的错误,也许导致整个体系无法正常行使

4,错误动静

错误动静,是关于错误的描写性文本,可所以SQL Server体系预界说的错误信息,也可所以THROW呼吁抛出的用户自界说的文本。

二,抛出非常动静

在SQL Server 2012及之后的版本中,行使 Throw 要害字取代RAISERROR,用于抛出非常,并将执行节制权转移到Catch 代码块。

THROW [error_number, error_message, error_state];

参数注释:

error_number:错误代码,是一个int范例,数值必需大于5000,小于 2147483647,这是用户自界说的错误代码。

error_message:错误动静,范例是nvarchar(2048)

state:跟错误相干联的一个state,范例是tinyint,取值范畴是:0-255

留意:在THROW语句之前的语句,必需以分号; 末了。

当THROW语句用于抛出自界说的非常时,severty level 经常被配置为默认的16;当THROW用于re-throw,此时THROW 没有任何参数,处于CATCH代码块中,仅仅用于把CATCH捕捉的非常从头抛出,severty level,state,错误动静跟原始非常沟通。

例子1,抛出自界说的非常:

BEGIN TRY
  SELECT 1/0
END TRY
BEGIN CATCH
  ;THROW 51000, 'Divide by zero error encountered', 1; 
END CATCH;

SQL Server抛出的非常动静是,自界说的错误代码是51000,严峻级别(Severity Level)是16,错误状态是1,错误行是5:

Msg 51000, Level 16, State 1, Line 5

Divide by zero error encountered

例子2,重抛非常,把体系检测到的错误从Catch代码块中抛出:

BEGIN TRY
  SELECT 1/0
END TRY
BEGIN CATCH
  ;THROW; 
END CATCH;

SQL Server抛出的非常动静是,错误代码是8134,严峻级别(Severity Level)是16,错误状态是1,错误行是2:

Msg 8134, Level 16, State 1, Line 2

Divide by zero error encountered.

三,不受TRY...CATCH布局影响的错误

TRY...CATCH 只捕捉严峻级别从11到19的错误,不会捕捉严峻级别是1-10,20-24的错误。

假如session会体系打点员行使KILL呼吁杀掉,那么TRY...CATCH布局不会捕捉。

四,在事宜中处理赏罚非常

假如在TRY代码块天生的错误,导致当前事宜的状态酿成无效,那么该事宜就是不行提交的事宜(uncommittable transaction)。一个不行提交的事宜,只能执行read操纵,可能回滚(ROLLBACK TRANSACTION),不能执行TSQL语句来执行写操纵,该事宜也不能提交。函数XACT_STATE() 返回-1暗示,当前的事宜是不行提交的事宜;返回1暗示当前的事宜是可以提交的。数据库开拓职员必要通过XACT_STATE() 来对事宜执行提交或回滚的操纵。

譬喻,在事宜中处理赏罚非常,可以参考以下代码,在现实应用措施,可以把非常信息记录在数据表中,便于举办妨碍解除:

-- SET XACT_ABORT ON will render the transaction uncommittable when the constraint violation occurs.
SET XACT_ABORT ON;
 
BEGIN TRY
  BEGIN TRANSACTION;
    -- A FOREIGN KEY constraint exists on this table. This statement will generate a constraint violation error.
    DELETE FROM Production.Product
    WHERE ProductID = 980;
  -- If the delete operation succeeds, commit the transaction. The CATCH block will not execute.
  COMMIT TRANSACTION;
END TRY
BEGIN CATCH
  -- Test XACT_STATE for 0, 1, or -1.
  -- If 1, the transaction is committable.
  -- If -1, the transaction is uncommittable and should be rolled back.
  -- XACT_STATE = 0 means there is no transaction and a commit or rollback operation would generate an error.
 
  -- Test whether the transaction is uncommittable.
  IF (XACT_STATE()) = -1
  BEGIN
    --Logging Exception info, as the transaction is in an uncommittable state. Rolling back transaction.
    SELECT
      ERROR_NUMBER() AS ErrorNumber,
      ERROR_SEVERITY() AS ErrorSeverity,
      ERROR_STATE() AS ErrorState,
      ERROR_PROCEDURE() AS ErrorProcedure,
      ERROR_LINE() AS ErrorLine,
      ERROR_MESSAGE() AS ErrorMessage; 
    ROLLBACK TRANSACTION;
  END;
  -- Test whether the transaction is active and valid.
  IF (XACT_STATE()) = 1
  BEGIN
    --'The transaction is committable. Committing transaction.'
    COMMIT TRANSACTION;  
  END;
END CATCH;

总结

到此这篇关于SQL Server非常代码处理赏罚的文章就先容到这了,更多相干SQLServer非常代码处理赏罚内容请搜刮剧本之家早年的文章或继承赏识下面的相干文章但愿各人往后多多支持剧本之家!

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读