zoukankan      html  css  js  c++  java
  • SqlCacheDependency 基于表的缓存应用


       SqlCacheDependency基于表的缓存应用在sql2000,以及slq20005中实现的原理多一样,多是在需要检测的表上建立触发器,并且Asp.net运行时通过轮询机制来检测表数据是否更改.
      使用步骤
      首先保证数据库里有相应的基础结构,可以通过aspnet_regsql来配置,
      –S 服务器名称 –U 登陆ID –P 密码 –d 数据库名称 –t 要追踪的数据表的名称 –et
     或者通过代码来建立基本结构
     SqlCacheDependencyAdmin.EnableNotifications(string connStr);
     SqlCacheDependencyAdmin.EnableTableForNotifications(string connstr, string[] tables);
    效果一样的,
     下面为演示代码asp.net
     
         private AggregateCacheDependency GetDependencty()
        {
            AggregateCacheDependency aggDep = new AggregateCacheDependency();
            aggDep.Add(new SqlCacheDependency("CacheTest", "UserList"));
            aggDep.Add(new SqlCacheDependency("CacheTest", "UrlList"));
            return aggDep;
        }

    ---------------------
        private DataSet GetDataProxy()
        {
            DataSet ds = HttpRuntime.Cache["SQL2005_CacheTest_UserList"] as DataSet;
            if (ds == null)
            {
                AggregateCacheDependency cd = GetAggregateDependency();
                ds = GetData();
                HttpRuntime.Cache.Insert("SQL2005_CacheTest_UserList", ds, cd);
                Response.Write("来源为数据库!");
            }
            return ds;
        }

    ---------------------------

        protected void Button1_Click(object sender, EventArgs e)
        {
            GridView1.DataSource = GetDataProxy();
            GridView1.DataBind();

        }

      当需要缓存的记录集来自多个表时,就需要使用AggregateCacheDependency对象,
    AggregateCacheDependency 确保,当保存集合内任意一对象(CacheDependency)失效时,使它关联的缓存数据也失效果,
    同时也会使AggregateCacheDependency内所有的对象失效,这点比较重要,如果不是这样,那么本例GetDependencty()
    函数中:     
           aggDep.Add(new SqlCacheDependency("CacheTest", "UserList"));
            aggDep.Add(new SqlCacheDependency("CacheTest", "UrlList"));
    是同时添加了2个SqlCacheDependency的,如果其中一个失效不导致另外一个失效的话,那么httpruntime会继续跟踪另外一个没有更新的数据表,即轮询操作会继续,但根据跟踪Sql Server Profilter 的结果看,当任意一项失效后(数据表数据更新),轮询就会停止,
    直到用户重新建立一个AggregateChacheDependency为止,

     最后,基于表的数据库缓存必须在web.config文件中有如下配置
    <system.web>
    .....
      <caching>
       <sqlCacheDependency enabled="true" pollTime="10000">
        <databases>
         <add name="CacheTest" connectionStringName="SQL2005CacheTest" pollTime="10000"/>
        </databases>
       </sqlCacheDependency>
      </caching>

    </system.web>
    pollTime为论询时间,建议不要少于1分钟,或更长,不然建议不要使用此类缓存.
    name="CacheTest",中的CacheTest,作为SqlCacheDependency(dbEntryName,table)构造函数参数dbEntryName,的传递值.这点要注意下.

  • 相关阅读:
    wgcloud问题处理——被监控的客户机掉线
    WGCLOUD下发指令时候如何屏蔽linux敏感字符
    WGCLOUD左侧菜单如何保持展开状态
    zerotier 实现 minecraft 局域网联机 | 我的世界联机教程 | minecraft联机
    [ UVa 12096 详解] The Set Stack Computer 集合栈计算机 | map、set、vector、stack、宏函数等知识点简单应用
    [ Uva 101 详解 ] the block problem 木块问题
    Python操作数据库基本操作-sqlalchemy
    统计目录下程序源程序的行数之和-Python
    凯撒密码C++实现
    【题解】[AGC036F] Square Constraints
  • 原文地址:https://www.cnblogs.com/wdfrog/p/1078593.html
Copyright © 2011-2022 走看看