挖掘使用ADO.NET StateChange事件技巧
创始人
2024-06-11 11:50:33
0

ADO.NET还是比较常用的,于是我研究了一下使用ADO.NET StateChange事件,在这里拿出来和大家分享一下,ADO.NET StateChange事件在 Connection 的状态改变时发生。 ADO.NET StateChange事件接收 StateChangeEventArgs,使您能够使用 OriginalState 和 CurrentState 属性来确定 Connection 状态的改变。
◆OriginalState 属性是一个 ConnectionState 枚举,指示改变前的 Connection 状态。
◆CurrentState 是一个 ConnectionState 枚举,指示改变后的 Connection 状态。

以下代码示例在 Connection 的状态改变时使用ADO.NET StateChange事件将消息写入控制台。

Visual Basic

  1. ' Assumes connection represents a SqlConnection object.  
  2. AddHandler connection.StateChange, _  
  3. New StateChangeEventHandler(AddressOf OnStateChange)  
  4.  
  5. Protected Shared Sub OnStateChange( _  
  6. sender As Object, args As StateChangeEventArgs)  
  7.  
  8. Console.WriteLine( _  
  9. "The current Connection state has changed from {0} to {1}.", _  
  10. args.OriginalState, args.CurrentState)  
  11. End Sub  

C#

  1. // Assumes connection represents a SqlConnection object.  
  2. connection.StateChange+= new StateChangeEventHandler(OnStateChange);  
  3.  
  4. protected static void OnStateChange(object sender,   
  5. StateChangeEventArgs args)  
  6. {  
  7. Console.WriteLine(  
  8. "The current Connection state has changed from {0} to {1}.",  
  9. args.OriginalState, args.CurrentState);  
  10. }  
  11.  
  12. }  

#T#通常,只有从服务器发出的信息性消息和警告消息才会触发 InfoMessage 事件。 但是,真正的错误发生时,启动服务器操作的 ExecuteNonQuery 或 ExecuteReader 方法将暂停执行,并引发异常。如果无论服务器生成任何错误都要继续处理命令中的语句的其他部分,请将 SqlConnection 的 FireInfoMessageEventOnUserErrors 属性设置为 true。 这样做会使连接对错误触发 InfoMessage 事件,而不是引发异常并中断处理。 客户端应用程序可以处理此事件并对错误情况做出响应。

严重程度等于或大于 17 的错误会造成服务器停止处理命令,这种错误必须作为异常来处理。 在这种情况下,无论如何在 InfoMessage 事件中处理该错误,都会引发异常。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...