WEB开发网
开发学院数据库MSSQL Server 基于SQL Server 的Exception Handling - PART III... 阅读

基于SQL Server 的Exception Handling - PART III

 2008-12-06 10:15:26 来源:WEB开发网   
核心提示: 在Main()中调用这个CreateUser():在这里我想特别说明一下SqlException.Number这个属性,它代表Database中的Error number[或者是@@ERROR、imessage_id],基于SQL Server 的Exception Handling -

在Main()中调用这个CreateUser():

基于SQL Server 的Exception Handling - PART III

在这里我想特别说明一下SqlException.Number这个属性,它代表Database中的Error number[或者是@@ERROR、imessage_id],不过当我们使用RAISERROR语句,如果我们指定的一个表示error message的字符串,ADO.NET捕获的SqlException.Number这个属性默认为50000。比如我们将Error number换成error message:

SET @error_message  = ERROR_MESSAGE()
SET @error_serverity  =ERROR_SEVERITY()
SET @error_state  = ERROR_STATE()
RAISERROR(@error_message, @error_serverity,@error_state)

将会得到这样的结果:

基于SQL Server 的Exception Handling - PART III

还有一点需要特别提醒得是,我们可以在调用RAISERROR加了一个WITH SETERROR重句,强制将当前@@ERROR的值返回到客户端:

基于SQL Server 的Exception Handling - PART IIIRAISERROR(@error_message,@error_serverity,@error_state)WITHSETERROR

七、  InfoMessage

上面的所以内容都围绕一个Exception handling的主题,在文章最后一部分我们想想一个和非Exception handling但是又和上面的内容很相关的主题:在Database通过Print语句输出的Message如何向Application传递。

在上面的例子中,有一个P_CLEAR_DATA的stored procedure,用于数据的清理。在操作结束后,有一个Print语句(PRINT ('All data have been deleted!'))

CREATE Procedure P_CLEAR_DATA
AS
  
  DELETE FROM dbo.T_USERS_IN_ROLES
  DELETE FROM dbo.T_USERS
  DELETE FROM dbo.T_ROLES
  
  PRINT ('All data have been deleted!')
  
GO

我们的现在的目标是在Application中,如何得到这段Message。要做到这点很简单,只需要用到SqlConnection的InfoMessage事件,当通过DbCommand执行上面一段Sql的时候,Print语句的执行将出发该事件。我们现在要做的就是注册这个事件,比如下面我们在ExecuteCommand()种添加了下面一段代码:

SqlConnection sqlConnection = connection as SqlConnection;
if (sqlConnection != null)
  {
     sqlConnection.InfoMessage += delegate(object sender, SqlInfoMessageEventArgs e)
     {
            Console.WriteLine(e.Message);
      };
   }

当我们调用Utility.Clear()的时候,就会输出"All data have been deleted!"

基于SQL Server 的Exception Handling - PART III

上一页  1 2 

Tags:基于 SQL Server

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接