加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server中开展错误处理的操作是什么

发布时间:2023-05-09 14:08:54 所属栏目:MsSql教程 来源:
导读:关于“SQL Server中进行错误处理的操作是什么”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友
关于“SQL Server中进行错误处理的操作是什么”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。
 
一、SQLServer数据库引擎错误
 
1、查询系统错误信息
 
SQLServer在每个数据库的系统视图sys.messages中存储系统自定义(Message_id <= 50000)和用户自定义(Message_id>50000)错误消息。
 
2、系统错误信息的严重性级别
 
得到的系统错误消息分为不同程度的严重性级别。严重性级别是通过数字来表示的,数字越小表示严重级别越低。反之则严重性越高。严重性较高的错误指示需要尽快解决问题。
 
二、用try...catch发现错误
 
try...catch结构       
 
begin try
 
        要执行的T-SQL代码,一旦错误将传递给catch块进行处理
 
      end try
 
      begin catch
 
        检索和处理错误信息的代码
 
      end catch
 
      正常执行的T-SQL语句
 
try:其中,try块是包含在begin try和end try之间的T-SQL代码段,在该代码段中一旦发生错误将传递给catch块,如果没有错误将直接执行catch块后面的代码。
 
catch:catch块是包含在begin catch和end catch之间的T-SQL代码段,在该代码段中检索和处理try块中的错误信息。
 
三、捕获错误的系统函数
 
error_number()
 
返回错误的ID号,对应sys.messages系统视图中的message_id字段。
 
error_line()
 
返回T-SQL代码中错误出现的语句行数。
 
error_message()
 
返回将返回给应用程序的消息文本。该文本包括为所有可替换参数提供的值,如长度、对象名或时间。对应sys.messages系统视图中的text字段。
 
error_procedure()
 
返回出现错误的存储过程或触发器名称。如果在存储过程或触发器中未出现错误,该函数返回NULL。
 
error_severity()
 
返回错误的严重性级别。对应sys.messages系统视图中的severity字段。
 
error_state()
 
返回状态
 
 示例:
 
begin try
 
    select 1/0
 
end try
 
begin catch
 
    select
 
        error_number() as 'number',
 
        error_line() as 'line',
 
        error_message() as 'message',
 
        error_severity() as 'severity',
 
        error_state()    as 'state'
 
end catch
 
四、用@@ERROR捕获上一条语句的错误
 
T-SQL还提供了一个简单的系统函数@@ERROR来捕获上一条语句的错误。如果上一条语句执行成功。@@ERROR系统函数将返回0;如果上一条语句生成错误,@@ERROR将返回错误号。
 
每条语句完成时@@ERROR都会更改。
 
例如:
 
select 1/0
 
select * from sys.messages where message_id = @@error and language_id = 2052
 
 结果如图:
 
 
 
五、用RAISERROR反馈错误
 
功能:
 
将生成的SQLServer引擎错误或警告信息(从sys.messages系统视图获得)反馈到应用程序中。sys.messages系统视图中由SQLServer自身定义的信息,其message_id列的值小于等于5000。
 
返回用户使用存储过程sp_addmessage创建的自定义消息(存储在系统视图sys.messages中,其message_id大于50000)。
 
与print语句的区别:
 
print语句是T-SQL提供的用于反馈信息的语句,print语句只能反馈字符串或字符串表达式的值。
 
raiserror语句除了print语句的功能外,还支持类似C语言仲printf函数的字符串替换功能。这样可以先在字符串中定义要替换的数据的类型和位置,在输出时自动将字符串内容进行替换。
 
语法: 
 
raiserror({ msg_id | msg_str | @local_variable })
 
        { ,severity,state }
 
         [ ,argument [ ,...n ] ] )
 
         [ with option [,...n] ]
 
参数说明:
 
msg_id:存储在sys.messages系统视图中的错误消息号(message_id)。如果是用户使用as_addmessage系统存储过程自定义的错误消息,其错误号应当大于50000.如果未指定msg_id,则返回一个错误号为50000的错误消息。
 
msg_str:用户自定义消息,msg_str是一个字符串,具有可选的嵌入转换规格。每个转换规格都会定义参数列表中的值。如何格式化并将其置于msg_str中转换规格位置上的字段中,转换规格的格式如下:%[[flag][width][.precision][{h|1}]]type。
 
@local_variable:包含按照msg_str的方式格式化的字符串的任何有效字符串数据类型的变量。@local_variable的数据类型必须为char或varchar,或者必须能够隐式转换为这些数据类型。
 
severity:用户定义的与该消息关联的严重级别。当使用msg_id引发使用sp_addmessage创建的用户定义消息时,paiserror上指定的严重性将覆盖sp_addmessage中指定的严重性。
 
state:状态号,1至少127之间的任意整数。如果在多个位置引发相同的用户自定义错误,则针对每个位置使用唯一的状态好有助于找到引发错误的代码段。
 
argument:用于代替msg_str或对应于msg_id的消息中的定义的变量的参数。可以有0个或多个替代参数,但是替代参数的总数不能超过20个。
 
option:错误的自定义选项。LOG:在SQLServer数据库引擎实例的错误日志和应用程序日志中记录错误;NOWAIT:将消息立即发送给客户端;SETERROR:将@@ERROR值和ERROR_NUMBER值设置为msg_id或50000,不用考虑严重级别。
 
 

(编辑:聊城站长网)

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

    推荐文章