SQL Server中进行错误处理的操作是什么
Admin 2022-08-04 群英技术资讯 607 次浏览
SQLServer在每个数据库的系统视图sys.messages中存储系统自定义(Message_id <= 50000)和用户自定义(Message_id>50000)错误消息。
得到的系统错误消息分为不同程度的严重性级别。严重性级别是通过数字来表示的,数字越小表示严重级别越低。反之则严重性越高。严重性较高的错误指示需要尽快解决问题。
try...catch结构
begin try 要执行的T-SQL代码,一旦错误将传递给catch块进行处理 end try begin catch 检索和处理错误信息的代码 end catch 正常执行的T-SQL语句
示例:
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
输出结果如图所示:
T-SQL还提供了一个简单的系统函数@@ERROR来捕获上一条语句的错误。如果上一条语句执行成功。@@ERROR系统函数将返回0;如果上一条语句生成错误,@@ERROR将返回错误号。
每条语句完成时@@ERROR都会更改。
例如:
select 1/0 select * from sys.messages where message_id = @@error and language_id = 2052
结果如图:
将生成的SQLServer引擎错误或警告信息(从sys.messages系统视图获得)反馈到应用程序中。sys.messages系统视图中由SQLServer自身定义的信息,其message_id列的值小于等于5000。
返回用户使用存储过程sp_addmessage创建的自定义消息(存储在系统视图sys.messages中,其message_id大于50000)。
print语句是T-SQL提供的用于反馈信息的语句,print语句只能反馈字符串或字符串表达式的值。
raiserror语句除了print语句的功能外,还支持类似C语言仲printf函数的字符串替换功能。这样可以先在字符串中定义要替换的数据的类型和位置,在输出时自动将字符串内容进行替换。
语法:
raiserror({ msg_id | msg_str | @local_variable }) { ,severity,state } [ ,argument [ ,...n ] ] ) [ with option [,...n] ]
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
SQL FOREIGN KEY 约束是什么?有不少朋友对于比较感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
这篇文章介绍了SQL Server中的事务用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
小编新安装了sqlserver用navicat进行连接时出现一系列问题,不知道该怎么解决,小编小编给大家分享一篇教程关于Navicat连接SQL Server数据:报错08001-命名管道提供程序的问题,感兴趣的朋友一起看看吧
这篇文章给大家分享的是有关sql server 文件操作的内容。小编觉得挺实用的,因此分享给大家作个参考,感兴趣的朋友就继续往下看吧。
这篇文章主要介绍了SQL Server 远程更新目标表数据的存储过程,适用于更新列名一致,主键为Int类型,具体实例代码大家参考下本文
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008