谈谈基于SQL Server 的Exception Handlingp[下篇]
六、SqlException
在上面一节中,我给出了一个完整的例子说明了:如何在将message定义在sys.messages中保证message的一致性和可维护性;如何在Stored procedure中使用RAISERROR将一个可预知的Error抛出;如何在TRY/CATCH进行异常的捕捉;在Application如果处理从SQL Server抛出的Exception。实际上,SQL Server database Engine抛出、被我们的.NET最终捕获的SqlException,我们通过SqlException的属性可以得到Error的相关信息。下面是SqlException的属性列表: ?
? 在stored procedure中,遇到重名通过RAISERROR抛出异常[在整篇文章中,使用到Exception,大家可以看成是等效的]: 我们来修正一下CreateUser方法:
![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() 在Main()中调用这个CreateUser():
将会得到这样的结果:
)?WITH?SETERROR
七、??? InfoMessage上面的所以内容都围绕一个Exception handling的主题,在文章最后一部分我们想想一个和非Exception handling但是又和上面的内容很相关的主题:在Database通过Print语句输出的Message如何向Application传递。 在上面的例子中,有一个P_CLEAR_DATA的stored procedure,用于数据的清理。在操作结束后,有一个Print语句(PRINT ('All data have been deleted!'))
CREATEProcedure?P_CLEAR_DATA
我们的现在的目标是在Application中,如何得到这段Message。要做到这点很简单,只需要用到SqlConnection的InfoMessage事件,当通过DbCommand执行上面一段Sql的时候,Print语句的执行将出发该事件。我们现在要做的就是注册这个事件,比如下面我们在ExecuteCommand()种添加了下面一段代码:
SqlConnection?sqlConnection??connection?as?SqlConnection;
?当我们调用Utility.Clear()的时候,就会输出"All data have been deleted!" (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 不能在此路径中使用此配置节。如果在父级别上锁定了该节,便
- asp.net – 使用facebook登录的asp .net 4.0会员资格
- asp.net – 与?之间的区别?
- ASP.NET成员:拒绝用户阻止CSS,页面无法正确呈现?
- ASP.NET MVC学习教程之Razor语法
- asp.net – IIS 7.0不允许下载MP4视频
- asp.net-mvc – 接受逗号和点作为小数分隔符[重复]
- asp.net-web-api – SimpleInjector RegisterWebApiRequest
- asp.net – 在2K3构建服务器上的单元测试中不允许使用’应用
- asp.net-mvc-4 – 如果使用实体连接字符串(与SQL连接字符串
- asp.net-mvc – 使用ASP.NET MVC,如何在外部控制
- asp.net – .net MVC将linq数据从控制器传递到视
- asp.net-mvc – 从DataAnnotation类中渲染LabelF
- asp.net-mvc-3 – MvcContrib网格和复选框
- asp.net – 为自定义UserControl提供呈现HTML中的
- asp.net – IE8 Win7 Facebook Connect问题
- asp.net-mvc – Rotativa和Bootstrap网格样式
- asp.net – System.Web.Providers – > Microsof
- 为什么我不能在运行时编辑我的ASP.NET Web应用程
- asp.net-core-mvc – 如何在Asp.net Core MVC(又