
其一般有两种捕捉错误的方法,一种是在客户端代码(如C#、Delphi等)中使用类似try...catch的语句进行捕捉;另外一种就是在Transact-SQL中利用Transact-SQL本身提供的错误捕捉机制进行捕捉。如果是因为Transact-SQL语句的执行而产生的错误,如键值冲突,使用第一种和第二种方法都可以捕捉,但是如果是逻辑错误,使用客户端代码进行捕捉就不太方便。因此,本文就如何使用Transact-SQL进行错误捕捉进行了讨论。 一、非致命错误(non-fatal error)的捕捉 通过执行Transact-SQL而产生的错误可分为两种:致命错误(fatal error)和非致命错误(non-fatal error)。在Transact-SQL中只可以捕捉非致命错误(如键值冲突),而无法捕捉致命错误(如语法错误)。在Transact-SQL中可以通过系统变量@@ERROR判断最近执行的一条语句是否成功执行。如果发生了错误,@@Error的值大于0,否则值为0。下面举一个例子说明@@ERROR的使用。 假设有一个表table1,在这个表中有两个字段f1,f2。其中f1是主键。 INSERT INTO table1 VALUES(1, 'aa') INSERT INTO table1 VALUES(1, 'bb') --这条语句将产生一个错误 IF @@ERROR > 0 PRINT '键值冲突' 当执行第二条语句时发生键值冲突错误,@@ERROR被赋为错误号2627,因此输出结果显示'键值冲突'。使用@@ERROR系统变量时需要注意,@@ERROR只记录最近一次执行的Transact-SQL语句所发生的错误,如果最近一次执行的Transact-SQL没有发生错误,@@ERROR的值为0。因此,只能在被捕捉的那条Transact-SQL语句后使用@@ERROR。 在SQL Server中,不仅可以捕捉系统提供的错误,还可以自定义错误。有两种方法可以定义错误信息。 1、使用sp_addmessage系统存储过程添加错误信息,然后使用RAISERROR抛出错误。 sp_addmessage将错误号,错误级别、错误描述等信息添加到系统表中,然后使用RAISERROR根据相应的错误号抛出错误信息。用户自定义的信息应该从50001开始。 本文来源:https://www.wddqw.com/BqKn.html 正在阅读: 2017年计算机等考三级数据库辅导:SQLServer2005捕捉错误的2种方案09-17 爱心之窗作文700字01-27 重庆考区2022年国考考点分布安排09-05 BEC商务英语口语考试常用词汇话题03-24 2018年中级会计职称真题答案,天津武清2018年中级会计职称报名入口:全国会计资格评价网04-08 寒假社会实践报告1500字 大学生:寒假社会实践报告心得1500字三篇02-25 小学生奥数和倍问题、相遇问题练习题10-17 少儿睡前温馨童话小故事文字版【四篇】08-23 [《生命流泪的样子》读后感1500字]《生命流泪的样子》读后感400字五篇10-23 你也是一颗珍珠作文500字07-25