在SQL2005数据库 中进行错误捕捉(2)_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

在SQL数据库2005 中进行错误捕捉(2)

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:捕捉错误进行数据库
黑客防线网安网讯:    基于上述原因,RAISERROR不仅可以根据错误代码抛出错误信息,也可以直接通过错误描述格式字符串抛出错误信息。RAISERROR('sql遇到了一个错误(%s)', 16, 1, '测试')二、...

    基于上述原因RAISERROR不仅可以根据错误代码抛出错误信息也可以直接通过错误描述格式字符串抛出错误信息

RAISERROR('sql遇到了一个错误(%s)', 16, 1, '测试')

二、逻辑错误的捕捉

在实际应用中,更多的是由于某些业务要求而产生的逻辑错误这些错误无法通过@@ERROR进行捕捉。如果使用客户端代码进行捕捉,那么Transact-SQL必须一条一条地执行。如果使用存储过程,那么发生在存储过程内部的逻辑错误就很难在客户端代码中进行捕捉,因此,下面将讨论如何使用Transact-SQL捕捉逻辑错误。

所谓逻辑错误,就是在执行完Transact-SQL后,执行结果与业务要求的结果不符而产生的。为了说明如何处理逻辑错误,我们再建立一个表table2,这个表的结构和table1完全一样,只是f1字段不再是主键了。然后建立一个存储过程,它的功能是在table1和table2中同时插入一条记录,但是这条记录必须满足两个条件。

1、f1值不能大于100。

2、要插入的记录在table1中不存在,如果存在,在table1和table2中都不插入这条记录。

      
CREATE PROCEDURE p1(@Num int)
        AS
        DECLARE @Error int, @RowCount int
        BEGIN TRANSACTION
        INSERT INTO table2 VALUES(@Num, 'p')
        IF @Num > 100
        BEGIN
        RAISERROR('%s的值不能大于100。', 16, 1, '@Num')  
        ROLLBACK TRANSACTION
        RETURN 1
        END
        ELSE
        BEGIN
        SELECT f1 FROM table1 WHERE f1 = @Num
        IF @@ROWCOUNT > 0
        BEGIN
        RAISERROR('table1中已经存在%d了。', 16, 1, @Num)
        ROLLBACK TRANSACTION
        RETURN 2
        END
        ELSE
        BEGIN
        INSERT INTO table1 VALUES(@Num, 'p')
        COMMIT TRANSACTION
        RETURN 0
        END
        END


在这个存储过程中一开始使用BEGIN TRANSACTION显示地开始一个事务,然后当上述两种错误发生时使用ROLLBACK TRANSACTION恢复到初始状态,如果成功插入,使用COMMIT TRANSACTION提交改变。可以通过如下语句进行调用。

DECLARE @ErrNum int
EXEC @ErrNUm = p1 2
PRINT @ErrNum

可以通过@ErrNum得到p1返回的错误代码,如果返回0,表示执行成功。

sql Server2005中错误捕捉的新功能

虽然在以前的SQL Server版本中可以通过一些技巧实现错误捕捉,但有时需要增加一些额外的开销,如在p1中使用了SELECT语句。庆幸的是在SQL Server2005中提供了和大多数编程语言类似的try...catch错误捕捉功能,从而使Transact-SQL第一次可以真正地进行错误捕捉。使用try...catch可以将p1的下半部分改写为如下形式。

      
ELSE
        BEGIN
        BEGIN TRY
        INSERT INTO table1 VALUES(@Num, 'p')  
        COMMIT TRANSACTION
        RETURN 0
        END TRY
        BEGIN CATCH
        RAISERROR('table1中已经存在%d了。', 16, 1, @Num)
        ROLLBACK TRANSACTION
        RETURN 2
        END CATCH
        END

 

可以看出,这个改写的部分未使用SELECT查询table1中是否已经有了某条记录,而是通过数据库的约束来进行判断的。如果键值冲突,就产生了错误,这样SQL语句就直接跳到BEGIN CATCH中执行错误处理代码。这样做效率要比上一个版本高得多,而且如果将RAISERROR去掉,p1就不会抛出任何错误,只是返回了一个错误码,这样有利于客户端代码进行处理。

在Tran

 

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-11302-1.html
网站维护教程更新时间:2012-03-21 03:19:34  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer