SQL Server中进行错误处理的操作是什么
Admin 2022-08-04 群英技术资讯 491 次浏览
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 SELECT DISTINCT语法用于仅返回不同的(different)值。在一张表内,一列通常包含许多重复的值; 有时你只想列出不同的(different)值。SELECT DISTINCT语句用于仅返回不同的(different)值。
大部分数据库语句的基本语法是相同的,但具体到的每一种数据库,又有些不一样,例如触发器,DB2和SQL Server两种很大的不同。对数据库触发器DB2和SqlServer有哪些区别感兴趣的朋友一起看看本文吧
在SQL中,我们经常会使用到查询操作,如果只是普通查询,可能会出现重复数据的情况,那么SQL要怎么实现查询且去掉重复数据呢?下面小编给大家介绍几种方法,有需要的朋友可以参考参考。
这篇文章主要给大家介绍的是关于Sql Server事务的语法以及使用,Sql Server事务是SQL数据库学习和使用需要掌握的重要内容,文本有对Sql Server事务语法的详解以及使用实例,具有一定的借鉴价值,需要的朋友可以学习参考。
这篇文章介绍了sql server排查死锁优化性能的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008