加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_开封站长网 (http://www.0378zz.com/)- 科技、AI行业应用、媒体智能、低代码、办公协同!
当前位置: 首页 > 服务器 > 系统 > 正文

一文带你搞懂sql异常代码如何处置

发布时间:2022-04-22 10:19:37 所属栏目:系统 来源:互联网
导读:我们在使用SQL Server时,经常会出现各种SQL语句异常,使用TRY...CATCH 结构能够进行异常捕获,下面我们就来详细看看TRY...CATCH如何使用以及SQL Server异常代码的处理,希望对大家学习有帮助,有需要的朋友就继续往下看吧。 SQL Server使用TRY...CATCH 结构
       我们在使用SQL Server时,经常会出现各种SQL语句异常,使用TRY...CATCH 结构能够进行异常捕获,下面我们就来详细看看TRY...CATCH如何使用以及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子句中,使用以下函数,能够获取异常发生时的信息。
 
       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:致命的错误,可能导致整个系统无法正常使用

(编辑:开发网_开封站长网)

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

    热点阅读