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,的传递值.这点要注意下.
转载于:https://www.cnblogs.com/liyejun/archive/2009/03/25/1421238.html
相关资源:垃圾分类数据集及代码