当前位置:首页 > 网络编程 > WEB编程 > ASP.net >  [原创]谈谈基于SQL Server 的Exception Handling-PART3

 [原创]谈谈基于SQL Server 的Exception Handling-PART3

点击次数:25 次 发布日期:2008-11-26 10:33:42 作者:源代码网
源代码网推荐      六、SqlException
源代码网推荐  在上面一节中,我给出了一个完整的例子说明了:如何在将message定义在sys.messages中保证message的一致性和可维护性;如何在Stored procedure中使用RAISERROR将一个可预知的Error抛出;如何在Stored procedure中使用TRY/CATCH进行异常的捕捉;在Application如果处理从SQL Server抛出的Exception。实际上,SQL Server database Engine抛出、被我们的.NET最终捕获的SqlException,我们通过SqlException的属性可以得到Error的相关信息。下面是SqlException的属性列表:
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  
源代码网推荐  public SqlErrorCollection Errors { get; }
源代码网推荐  public int LineNumber { get; }
源代码网推荐  public int Number { get; }
源代码网推荐  public string Procedure { get; }
源代码网推荐  public string Server { get; }
源代码网推荐  public override string Source { get; }
源代码网推荐  public byte State { get; }
源代码网推荐  
源代码网推荐  有了前面的内容作铺垫,相信大家都知道每个属性分别表示的什么了吧。为了使大家对stored procedure的Error和ADO.NET捕获的Error的Mapping有一个更加清晰的认识。我们来写一个Sample,我们沿用Create User的例子:
源代码网推荐  
源代码网推荐  在stored procedure中,遇到重名通过RAISERROR抛出异常[在整篇文章中,使用到Error和Exception,大家可以看成是等效的]:
源代码网推荐   · Error Number:50001
源代码网推荐   · Severity:16
源代码网推荐   · State:1
源代码网推荐   · Message:This user is already existent
源代码网推荐  
源代码网推荐  我们来修正一下CreateUser方法:
源代码网推荐  
源代码网推荐  
源代码网推荐  public static bool CreateUser(string userName)
源代码网推荐   {
源代码网推荐   string procedureName = "P_USERS_I";
源代码网推荐   Dictionary<string, object> parameters = new Dictionary<string, object>();
源代码网推荐   parameters.Add("user_id", Guid.NewGuid().ToString());
源代码网推荐   parameters.Add("user_name", userName);
源代码网推荐   try
源代码网推荐   {
源代码网推荐   ExecuteCommand(procedureName, parameters);
源代码网推荐   return true;
源代码网推荐   }
源代码网推荐   catch (SqlException ex)
源代码网推荐   {
源代码网推荐   Console.WriteLine("ex.Class : {0}", ex.Class);
源代码网推荐   Console.WriteLine("ex.ErrorCode : {0}", ex.ErrorCode);
源代码网推荐   Console.WriteLine("ex.LineNumber : {0}", ex.LineNumber);
源代码网推荐   Console.WriteLine("ex.Message : {0}", ex.Message);
源代码网推荐   Console.WriteLine("ex.Number : {0}", ex.Number);
源代码网推荐   Console.WriteLine("ex.Procedure : {0}", ex.Procedure);
源代码网推荐   Console.WriteLine("ex.Server : {0}", ex.Server);
源代码网推荐   Console.WriteLine("ex.Source : {0}", ex.Source);
源代码网推荐   Console.WriteLine("ex.State : {0}", ex.State);
源代码网推荐   return false;
源代码网推荐   }
源代码网推荐   }
源代码网推荐  
源代码网推荐  在Main()中调用这个CreateUser():
源代码网推荐  
源代码网推荐  在这里我想特别说明一下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)
源代码网推荐  
源代码网推荐  
源代码网推荐  将会得到这样的结果:
源代码网推荐  
源代码网推荐  还有一点需要特别提醒得是,我们可以在调用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!"
源代码网推荐  
源代码网推荐    做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。
源代码网推荐


源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华