SQL Server的Exception Handling

[ 来源:http://www.it55.com | 作者: | 时间:2007-12-18 | 收藏 | 推荐 ] 【


  还有一点需要特别提醒得是,我们可以在调用RAISERROR加了一个WITH SETERROR重句,强制将当前@@ERROR的值返回到客户端:
  
  RAISERROR(@error_message,@error_serverity,@error_state) WITH SETERROR
  七、 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!"
  
    

(编辑:IT资讯之家 www.it55.com

返回顶部
共8页: 上一页 [1] [2] [3] [4] [5] [6] [7] 8 下一页  
上一篇:实时监控网站运行情况的三种方法   下一篇:没有了

网友评论

[以下评论为网友观点,不代表本站。请自觉遵守互联网相关政策法规,所有连带责任均有评论者自负。]
[不超过250字]