与数据库进行交互操作的时候会发生很多错误,但是很多开发人员都不知道如何处理数据库层的错误。本文我们探讨如何利用SQL Server和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( -- raise a custom error message so record is updated |
列表A
如果没有错误发生,它就把电话号码列设置为一个值,传递给过程。它使用一个返回值参数,如果有问题发生它就返回一个负值,如果用所有的东西都执行没有问题,它会返回一个正值。
用存储过程返回值
通过存储过程返回值,我们可以把它用在我们的.NET代码里。SqlCommand对象允许你很容易就添加参数传递给过程以及存储返回值。参数的 Direction属性被用来接收来自存储过程调用的值。它有两个属性值:InputOutput和Output。在我们的例子里,我们将使用 Output来接收状态值。
这段代码是一个简单的ASP.NET页面,用来传递一个用于Northwind数据库的客户表格里某个数据的新值。而id值事实上被保存在一个隐藏字段里,可以被轻易地传递给表单,但是这个字段是用来说明的。在文本字段输入的值被用更新数据库表格里的电话号码字段。
参数被添加给SqlCommand对象(它们必须精确地符合存储过程的参数值)。命令通过SqlCommand对象的ExecuteNonQuery方法被执行。一旦它已经被执行,返回的值可以通过参数来取回。
代码会检查返回的值(-1表示有问题),而消息会显示在一个Label控件里。此外,一个try/catch块被用来捕捉在与数据库进行交互操作过程中可能发生的任何致命错误。看看列表B:
VB.NET代码:
TechRepublic.com - Test New Number: OnCommand="btnUpdatePhone_Click" runat="server"/> ALFKI |
列表B
涵盖所有的数据库
利用try/catch代码块来处理.NET应用程序代码里的异常是一个简单明了的过程,但是你还可以监视数据库层的异常。SQLServer的T-SQL语言为你处理代码异常提供了所需要的一切。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/1697933/viewspace-891306/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/1697933/viewspace-891306/