• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
一个具有上进心的码农
因为一篇文章中有很多是从很多篇文章中摘取的,请恕我没有一一说明摘取出处,如果没有说明,则该文章默认是摘取,如有侵犯您的权益,请与我联系,将会马上删除。
博客园    首页    新随笔    联系   管理    订阅  订阅

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,的传递值.这点要注意下

posted @ 2008-07-07 11:48  不若相忘于江湖  阅读(1078)  评论(3)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3