浅谈在SQL Server2005中进行错误捕捉(2)_Mssql数据库教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:解析SQL Server 2000 SP4与数据链接池问题
今天远程连接一台xp sp2上的SQL,报错信息如下: 以下为引用的内容:   Timeout expired. The timeout period elapsed prior to obtaining

在SQL Server中,不仅可以捕捉系统提供的错误,还可以自定义错误。有两种方法可以定义错误信息。

1、使用sp_addmessage系统存储过程添加错误信息,然后使用RAISERROR抛出错误。

sp_addmessage将错误号,错误级别、错误描述等信息添加到系统表中,然后使用RAISERROR根据相应的错误号抛出错误信息。用户自定义的信息应该从50001开始。

以下为引用的内容:

  exec sp_addmessage @msgnum = 50001, @severity = 16,

  @msgtext = ’sql encounter an error(%s).’,

  @lang = ’us_english’

  exec sp_addmessage @msgnum = 50001, @severity = 16,

  @msgtext = ’sql遇到了一个错误(%1!).’

如果使用的SQL Server版本是非英语版本,在添加本地错误信息时必须首先添加英文的错误信息。错误描述可以象c语言中的printf的格式字符串一样使用参数,如%s、%d。但要注意的是在英文版的错误信息中要使用%s、%d等形式,而在本地化的错误信息中要使用%1!、%2!等形式,在每个%?(1 <= ? <= n)后需要加一个!,而且%?的数目必须和英文版的错误信息的参数一致。

在未插入本地化错误信息时,RAISERROR将使用英文版的错误信息。当插入本地化错误信息时,RAISERROR使用本地化的错误信息。

RAISERROR(50001, 16, 1, ’测试’)

输出的结果:

服务器: 消息 50001,级别 16,状态 1,行 1

sql遇到了一个错误(测试).

其中’测试’字符串通过%1传入本地化的错误描述字符串中。

2、直接使用RAISERROR将错误抛出。

使用第一种方法虽然使Transact-SQL语句看上去更整洁(这种方法类似于在编程语言中使用常量定义错误信息,然后在不同的地方通过错误编号引用这些错误信息。),但是这样做却使错误信息和数据库的耦合度增加,因为如果将这些带有RAISERROR的Transact-SQL放到别的SQL Server数据库上执行,由于在其它的数据库中还未添加错误信息,因此会产生RAISERROR调用错误,除非使用sp_addmessage将所需的错误信息再加入到其它的数据库中。

分享:解析SQL Server 2008对T-SQL语言的增强
Microsoft SQL Server 2008 对 T-SQL 语言进行了进一步增强。为了让开发人员尽快了解这些变化,我们针对 2007 年 6 月 CTP 版本的 SQL Server 2008 中的 T-SQL 语言的新增功能进行

来源:模板无忧//所属分类:Mssql数据库教程/更新时间:2009-09-01
相关Mssql数据库教程