当前位置: 首页 > news >正文

电子商务网站规划原则深圳网站建设推进

电子商务网站规划原则,深圳网站建设推进,校园失物招领网站建设,台州永建建设有限公司网站六、SqlException 在上面一节中#xff0c;我给出了一个完整的例子说明了#xff1a;如何在将message定义在sys.messages中保证message的一致性和可维护性#xff1b;如何在Stored procedure中使用RAISERROR将一个可预知的Error抛出#xff1b;如何在Stored procedure中使用…六、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 Number50001    ·         Severity16    ·         State1    ·         MessageThis 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.Class\t: {0}, ex.Class);                Console.WriteLine(ex.ErrorCode\t: {0}, ex.ErrorCode);                Console.WriteLine(ex.LineNumber\t: {0}, ex.LineNumber);                Console.WriteLine(ex.Message\t: {0}, ex.Message);                Console.WriteLine(ex.Number\t: {0}, ex.Number);                Console.WriteLine(ex.Procedure\t: {0}, ex.Procedure);                Console.WriteLine(ex.Server\t: {0}, ex.Server);                Console.WriteLine(ex.Source\t: {0}, ex.Source);                Console.WriteLine(ex.State\t: {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_DATAAS    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 I[原创]谈谈基于SQL Server 的Exception Handling - PART II[原创]谈谈基于SQL Server 的Exception Handling - PART III 转载于:https://www.cnblogs.com/artech/archive/2007/12/17/1002857.html
http://www.zqtcl.cn/news/681834/

相关文章:

  • 给新公司建网站中国互联网企业排名前十名
  • 中国建设银行网站会员用户名网站建设应列入啥费用
  • 网站上面的水印怎么做的广东网站建设公
  • 爱站网关键词长尾挖掘工具wordpress文章外链
  • 做视频剪辑接私活的网站网站商城系统设计
  • thinkphp5做网站做网站需要准备资料
  • 门户网站平台建设方案建e室内设计网cad
  • 西安网站建设收费标准第五次全国经济普查
  • 成品网站货源1688免费襄阳公司网站建设
  • 2020国内十大小说网站排名365网站
  • 潍坊做网站的网络公司网页设计入门教材pdf
  • 影视公司网站建设wordpress 500ms
  • 旅游网站建设公司crm客户管理系统模板
  • 哪个网站有免费的模板阿里云上如何用iis做网站
  • 中山优化网站门户网站建设jz190
  • 湖州服装网站建设网站备案和域名备案区别
  • 网站开发好学嘛网络安全工程师年薪
  • 17网站一起做网店睡衣网线制作流程
  • 广告网站设计公司好吗网站页面设计主要包括
  • 网站的做重庆市建设工程造价信息表
  • 建网站跟建网店的区别怎样营销建设网站
  • 医院做网站的风格乐清网站建设哪家好
  • 手机商城网站方案如何自己搭建微信小程序
  • 做影视免费网站违法吗青岛快速排名优化
  • 网站建设在电子商务中的作用的看法360地图怎么添加商户
  • 网站域名备案与不备案的区别wordpress 注册审核
  • 大学生做企业网站网页设计免费模板情侣
  • 商城网站建设教程网站开发支付宝
  • 广安网站设计快递加盟代理
  • 建设网站的建筑公司宿迁华夏建设集团网站