SqlCacheDependency 基于表的缓存应用
来源:互联网 发布:js数组转字符串 编辑:程序博客网 时间:2024/05/17 08:07
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;
}
---------------------------
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,的传递值.这点要注意下.
使用步骤
首先保证数据库里有相应的基础结构,可以通过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,的传递值.这点要注意下.
- SqlCacheDependency 基于表的缓存应用
- SqlCacheDependency缓存应用
- sqlCachedependency【数据缓存依赖】 的使用
- sql SqlCacheDependency缓存依赖
- 缓存+SqlCacheDependency(一)
- c#缓存-SqlCacheDependency类
- \t\t【总结】ASP.NET 缓存 SqlCacheDependency 监视数据库表变化 让缓存更新的更及时更提高节能
- SqlDependency和SqlCacheDependency缓存的用法及具体步骤
- SqlDependency和SqlCacheDependency缓存的用法及具体步骤
- SqlDependency和SqlCacheDependency缓存的用法及具体步骤
- SqlCacheDependency asp.net 页面缓存
- 强大的SqlCacheDependency
- 强大的SqlCacheDependency
- SqlCacheDependency的使用,高速缓存
- SqlCacheDependency的使用方法
- SqlCacheDependency
- SqlCacheDependency
- SqlCacheDependency
- 宛如,一个要强的女人――第三届英雄大会嘉宾专访
- Javascript数组及其操作
- 忆秦娥·汤浅比吕美
- 木兰花·仲上真一郎
- 满庭芳·林明美
- SqlCacheDependency 基于表的缓存应用
- Nano-X显示系统的代码分析
- 成就PHP高手的五个必由之路
- "将截断字符串或二进制数据。语句已终止。"
- C#关键字: Sealed, Abstract, Virtual和Interface
- 链表的逆转
- 基于树的多因素平衡组卷模型及算法设计
- 20 Ways To Train Your Brain For Peak Performance
- 66招Ubuntu8.04优化技巧