用SQL数据库处理数据层错误_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

用SQL数据库处理数据层错误

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

本篇关键词:错误数据处理数据库
黑客防线网安网讯:  开发人员在努力做到妥善地处理意外,这样用户就不用担心天书般的系统错误信息。出于这个原因,异常处理是每个.NET应用程序的一个标准部分。Try/catch块让你能够捕捉异常并从该点控制应...

  开发人员在努力做到妥善地处理意外这样用户就不用担心天书般的系统错误信息出于这个原因异常处理是每个.NET应用程序的一个标准部分Try/catch块让你能够捕捉异常并从该点控制应用程序的执行。与数据库进行交互操作的时候会发生很多错误,但是很多开发人员都不知道如何处理数据库层的错误。本文我们将探讨如何利用SQLServer和T-SQL来处理你数据库代码里的错误。

  处理T-SQL里的错误

  SQLServer的SQL对话让你能够轻松地处理可能会在存储进程、函数里发生的非致命错误,但是并不是所有的错误都很容易处理。事实上,致命和非致命的错误有很多。什么是致命的,什么是非致命的,对此没有很完备的文档说明,但是你的应用程序代码总是可以利用try/catch块来处理致命的数据库错误。对于其他所有的错误,你可以使用下面的技术。

  事务

  你应该在数据库代码里使用事务,以确保在一切都没有问题的时候所有的更改都被完成。SQLServer的在线帮助将事务描述为任务的一个逻辑单元,它由一系列语句(选择、插入、更新,或者删除等)组成。如果在事务期间没有发生任何错误,那么对事务的所有改动都会成为数据库的永久部分。如果在这期间发生了错误,不会对数据库进行任何修改。

  事务包含在BEGIN TRANSACTION和END TRANSACTION语句之间。ROLLBACK TRANSACTION语句可以取消所有的更改,因此不会发生任何变化。用COMMIT TRANSACTION语句可以进行永久的更改。现在,就让我们把注意力放在如何处理T-SQL里的错误上。

  @@Error

  @@Error函数让你可以实现T-SQL错误处理。它会返回由系统所返回的错误代码。如果没有错误发生就会返回“0”。@@Error函数必须紧接在一个语句之后立即被调用,因为它会在每个T-SQL语句之后被清除。

  RAISERROR

  RAISERROR语句让你能够生成一个自定义的错误信息或者使用一个放在sysmessages表格里的已有消息。你可以在线查看它的句法,但是它的最基本格式包括了消息(用于自定义的消息)或者消息id(用于已有的消息)和它的严重度及状态。SQLServer没有使用状态,所以随便传递给它一个数字就可以了。严重度表示了错误的严重程度,0-18供用户使用,而19-25保留给管理员使用。

  在列表A里,示例存储过程使用了这些特性来更新示例Northwind数据库里的一条记录:

CREATE PROCEDURE sp_UpdateCustomerPhone(
@id nvarchar(5),
@phone nvarchar(24),
@retvalueint output
) AS
BEGIN
BEGIN TRANSACTION
UPDATE [dbo].[Customers] SET [Phone] = @phone WHERE([CustomerID] = @id)
IF (@@ERROR <> 0) -- a non-negative value signals an error
BEGIN
ROLLBACK TRANSACTION -- changes are not permanent
RAISERROR('Update Customers Error',1,1)
-- raise a custom error message
-- Custom error message appears if run from console
SET @retvalue = -1 -- return negative value to signalproblems
END
COMMIT TRANSACTION -- make the changes permanent,
so record is updated
SET @retvalue = 1 -- a positive return value signalssuccess
RETURN
END
  列表A

  如果没有错误发生,它就把电话号码列设置为一个值,传递给过程。它使用一个返回值参数,如果有问题发生它就返回一个负值,如果用所有的东西都执行没有问题,它会返回一个正值。

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

footer  footer  footer  footer