c# – 什么时候调用DbConnection.StateChange?
我有以下代码:
class Program { static void Main() { var connection = new SqlConnection("myConnectionString"); connection.Open(); connection.StateChange += HandleSqlConnectionDrop; Console.WriteLine("Hi"); Console.ReadLine(); } private static void HandleSqlConnectionDrop(object connection,StateChangeEventArgs args) { Console.WriteLine("DB change detected"); } } 当SQL Server实例运行时,我启动上述代码.然后我继续执行 SHUTDOWN WITH NOWAIT; 在程序连接到的sql server实例上.然后我观察SQL Server服务停止.但是,我从来没有看到输出中的“DB change detected”消息.为什么是这样? 另外:如果我尝试在SQL连接上执行一个操作,但从来没有在手,我将看到StateChange处理程序被调用.有没有办法这种行为可以改变? 解决方法
您可以通过查看Microsoft参考源代码了解到.
首先,在SqlConnection类中,OnStateChange仅在 然后在 据我所知(部分类的废话使它变得困难),SqlConnection.SetInnerConnectionEvent只能从 > 因此,总而言之,事件只是响应客户端操作引起的 – 对SQLConnection内置的连接状态似乎没有任何轮询.
看源代码,我看不到一个.如其他人所建议的那样,当然可以实施你自己的投票. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |