加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 什么时候调用DbConnection.StateChange?

发布时间:2020-12-15 17:47:22 所属栏目:百科 来源:网络整理
导读:我有以下代码: class Program{ static void Main() { var connection = new SqlConnection("myConnectionString"); connection.Open(); connection.StateChange += HandleSqlConnectionDrop; Console.WriteLine("Hi"); Console.ReadLine(); } private stati
我有以下代码:
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处理程序被调用.有没有办法这种行为可以改变?

解决方法

When is DbConnection.StateChange called?

您可以通过查看Microsoft参考源代码了解到.

StateChange事件由DbConnection.OnStateChange功能提升.寻找对这个函数的引用仅产生一些实例:

首先,在SqlConnection类中,OnStateChange仅在Close方法中调用.

然后在DbConnectionHelper.cs文件中,有一个名为DBCONNECTIONOBJECT的部分类.它看起来像用于所有DbConnection派生类使用一些构建时间的shenanigans.所以你可以认为它是SqlConnection的一部分.无论如何,它仅在SetInnerConnectionEvent函数内调用OnStateChange.

据我所知(部分类的废话使它变得困难),SqlConnection.SetInnerConnectionEvent只能从SqlConnectionFactory.SetInnerConnectionEvent调用.这就是从:

> DbConnectionClosed.TryOpenConnection
> DbConnectionInternal.TryOpenConnectionInternal
> DbConnectionInternal.CloseConnection

因此,总而言之,事件只是响应客户端操作引起的 – 对SQLConnection内置的连接状态似乎没有任何轮询.

Is there a way this behavior can be changed?

看源代码,我看不到一个.如其他人所建议的那样,当然可以实施你自己的投票.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读