zoukankan      html  css  js  c++  java
  • SqlDependency 的使用

    1、SqlDependency是什么:

      SqlDependency 对象表示应用程序和 SQL Server 实例间的查询通知依赖关系。应用程序可以创建一个 SqlDependency 对象并进行注册以通过OnChangeEventHandler 事件处理程序接收通知。

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

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

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

    2、使用方法:

      1)sql server设置:ALTER DATABASE <DatabaseName> SET ENABLE_BROKER;语句让相应的数据库启用监听服务,以便支持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);
            }
  • 相关阅读:
    SQL Server 2005 中的分区表和索引 [轉]
    [导入]使用RDLC报表(一)
    正则表达式30分钟入门教程[轉]
    C#的TextBox控件输入测试只允许输入数字的测试:
    c#创建access数据库和数据表[转]
    [导入]使用RDLC报表(二)使用自定义数据集
    ASP.net 文件下載
    [导入]使用RDLC报表(四)钻取式报表
    [导入]使用RDLC报表(三)向RDLC报表传入参数
    C# SQL server2000中保存的图像
  • 原文地址:https://www.cnblogs.com/zhaoyihao/p/5663258.html
Copyright © 2011-2022 走看看