zoukankan      html  css  js  c++  java
  • .NET 2.0 SqlDependency快速上手指南

    此文以SQL Server 2005上实现为准,SQL Server 2000因为实现机制不同,请查阅相关资料。

     

           步骤一:在SQL Server 2005上执行ALTER DATABASE <DatabaseName> SET ENABLE_BROKER;语句让相应的数据库启用监听服务,以便支持SqlDependency特性。

           这条语句最好在数据库未执行任何事务的情况下执行。

     

           步骤二:调用SqlDependency.Start(String strConnectionString)方法,在应用程序端启用依赖监听器。

           该方法的参数为一个数据库的连接字符串,该数据库必须已经执行过步骤一的操作。

           对于同一连接字符串,若已经执行过该语句,再次执行不会发生任何异常,但返回值会为False.

           如果是在Web程序中使用,建议可以将该语句放在Application_Start事件中执行。

           监听是基于数据库的,而依赖才可以基于表或者查询。

     

           步骤三:该步骤分别有两种不同的做法。该阶段必须注意步骤。

                  方法A:建立连接对象,再创建一个SqlCommand实例,创建SqlCacheDependency实例,在这步之后再调用Command对象来获取数据(这个顺序很重要)。之后调用CacheInsert语句建立一个依赖于一个具体查询数据集的Cache项。


                 
    SqlConnection conn = new SqlConnection(strConnection);

             SqlCommand command = new SqlCommand(strCommandText, conn);

             SqlCacheDependency dependency = new SqlCacheDependency(command);

            

             // 注册方法到委托,该委托是

             CacheItemRemovedCallback onRemove = new CacheItemRemovedCallback(RemovedCallback);

             // 新增或修改一条缓存记录

             Cache.Insert(strCacheKey, objAppCache, dependency, absoluteExpiration, slidingExpiration, CacheItemPriority.Default, onRemove);

     

              方法B:建立连接对象,再创建一个SqlCommand实例,最后创建SqlDependency实例。定义SqlDependency的委托OnChange,当数据发生改变时做出相应的处理(比如清除Cache)。

                  SqlConnection conn = new SqlConnection(strConnection);

             SqlCommand command = new SqlCommand(strCommandText, conn);

             SqlCacheDependency dependency = new SqlCacheDependency(command);

                 

                  dependency.OnChange += new OnChangeEventHandler(Dependency_OnChange);

     

     

         注意事项:

           不知道是不是还存在BUG,我在项目开发中遇到一些奇怪的现象。同样的代码,在有的机器上运行则能捕捉到变化,有的则完全没反应;也有时会出现Cache刚建立就反复发生依赖改变的事件。偶尔Cache还会数据发生变化却不引发事件。

           但从最终项目实施的情况看,似乎都只是某些机器环境造成的不确定因素?这个无法确定。不过起码数据库端是否正常启用,可以通过SQL Server Profiler来查看监视。

  • 相关阅读:
    Kubernetes(k8s)中namespace的作用、反向代理访问k8s中的应用、k8s监控服务heapster
    Kubernetes(k8s)中dashboard的部署。
    Kubernetes(k8s)中Pod资源的健康检查
    Kubernetes(k8s)安装dns附件组件以及使用
    Kubernetes(k8s)的deployment资源
    Kubernetes(k8s)的Service资源
    Kubernetes(k8s)的RC(Replication Controller)副本控制器
    Kubernetes(k8s)常用资源的使用、Pod的常用操作
    简易图书管理系统(主要是jsp+servlet的练习),基于jsp+servlet的图书管理系统
    js 提取 sql 条件 表名 limit
  • 原文地址:https://www.cnblogs.com/Xrinehart/p/461106.html
Copyright © 2011-2022 走看看