基于SQL Server 的Exception Handling - PART III

2016-02-19 16:02 4 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐基于SQL Server 的Exception Handling - PART III,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - 编程语言 】

  六、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";
      Dictionarystring, object parameters = new Dictionarystring, 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.Classt: {0}", ex.Class);
        Console.WriteLine("ex.ErrorCodet: {0}", ex.ErrorCode);
        Console.WriteLine("ex.LineNumbert: {0}", ex.LineNumber);
        Console.WriteLine("ex.Messaget: {0}", ex.Message);
        Console.WriteLine("ex.Numbert: {0}", ex.Number);
        Console.WriteLine("ex.Proceduret: {0}", ex.Procedure);
        Console.WriteLine("ex.Servert: {0}", ex.Server);
        Console.WriteLine("ex.Sourcet: {0}", ex.Source);
        Console.WriteLine("ex.Statet: {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:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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)WITHSETERROR

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  七、  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!"

来源:http://www.tulaoshi.com/n/20160219/1610937.html

延伸阅读
以下为SQL SERVER7.0以上版本的字段类型说明。SQL SERVER6.5的字段类型说明请参考SQL SERVER提供的说明。 bit:0或1的整型数字 int:从-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型数字 smallint:从-2^15(-32,768)到2^15(32,767)的整型数字 tinyint:从0到255的整型数字 decimal:从-10^38到10^38-1的定精度与有效位数的数字 ...
标签: SQLServer
微软总是试图使它的软件安装尽可能地简单顺畅,SQL Server 2000的安装也不例外。你从安装光盘的x86 etup文件夹启动setupsql.exe、在安装对话框中填入一些细节后,几分钟内,安装将在没有用户介入的情况下继续执行。你甚至可以成功的安装SQL Server 2000而不用明白那些选择意味着什么——只需在大多数安装对话框中点击“下一步”。然而,我强烈建...
STUFF ( character_expression , start , length ,character_expression ) 参数 character_expression 一个字符数据表达式。character_expression 可以是常量、变量,也可以是字符列或二进制数据列。 start 一个整数值,指定删除和插入的开始位置。如果 start 或 length 为负,则返回空字符串。如果 start 比第一...
标签: SQLServer
SQL server锁的机制 SQL server的所有活动都会产生锁。锁定的单元越小,就越能越能提高并发处理能力,但是管理锁的开销越大。如何找到平衡点,使并发性和性能都可接受是SQL Server的难点。 SQL Server有如下几种琐: 1、 共享锁 用于只读操作(SELECT),锁定共享的资源。共享锁不会阻止其他用户读,但是阻止其他的用户写和修改。 2、 更新锁 ...
SQL Server是购买Sybase公司1987年推出的Sybase SQL Server, 又称为大学版INGRES的第三代产品,所以他们实质是一样的。 Sybase公司是1984年成立的,属于后起之秀。他推出了支持企业范围的“客户/服务器体系结构”的数据库。Sybase把“客户/服务器数据库体系结构”作为开发产品的重要目标。他们吸取了INGRES的研制经验,以满足联机事务...

经验教程

439

收藏

78
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部