1、SqlDependency是什么:

  OnChangeEventHandler 事件处理程序接收通知。

  它提供了这样一种能力:当被监测的数据库中的数据发生变化时,SqlDependency会自动触发OnChange事件来通知应用程序,从而达到让系统自动更新数据(或缓存)的目的。

  应用:数据实时性较高的场景、新闻、监控数据等。

  可以结合SignalR来实现web的实时数据更新。

2、使用方法:

SqlDependency特性。

  2)代码:控制台项目,web项目推荐把start放在Application_start方法中。

3)注意:查询语句中不能使用*,表名要加[dbo].[xx]。sql语句要执行。

conn =ConfigurationManager.ConnectionStrings["default"].ToString();
                //Start和Stop方法
                SqlDependency.Start(conn);
                Update(conn);


 private static void Update(string conn)
        {
            using (
                   SqlConnection connection =
                       new SqlConnection(conn))
            {
                //此处 要注意 不能使用*  表名要加[dbo]  否则会出现一直调用执行 OnChange
                string sql = "select agent from [dbo].[info]";
                
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    connection.Open();
                    command.CommandType=CommandType.Text;
                    dependency = new SqlDependency(command);
                    dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
                    //必须要执行一下command
                    command.ExecuteNonQuery();
                    Console.WriteLine(dependency.HasChanges);
                }
            }
        }



        //update insert delete都会进入
        private static void dependency_OnChange(object sender, SqlNotificationEventArgs e)
        {
            Console.WriteLine("onchange方法中:"+dependency.HasChanges);
            Console.WriteLine("数据库数据发生变化"+DateTime.Now);
            //这里要再次调用
            Update(conn);
        }

 

相关文章: