ASPNET缓存依赖

在大型门户网站上大量的应用了缓存,缓存就是将页面数据存储到内存空间中,在浏览器请求页面时不用经历页面生命周期直接从缓存中读取数据并返回给浏览器,缓存有页面缓存、数据源缓存、数据缓存等,这里主要介绍数据库缓存依赖

数据库缓存依赖

1.先注册数据库及表

DataBaseName:数据库名称

TableName:表名称

以下命令在cmd下执行(进入:C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727中)

注册依赖aspnet_regsql -S . -E -ed -dDataBaseName -et -t TableName

删除注册aspnet_regsql -S . -E -d DataBaseName -dt -t TableName

取消依赖:aspnet_regsql -S . -E -dd DataBaseName

列出已注册表:aspnet_regsql -S . -E -d DataBaseName –lt

2.在web.config配置文件中新增如下配置节点

<system.web>

<caching>

<sqlCacheDependency enabled="true">

<databases>

<add name="GSSMS" connectionStringName="conStr2" pollTime="15000"/>

</databases>

</sqlCacheDependency>

</caching>

示例代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.Caching;
using System.IO;
using System.Data;
using System.Text;

public partial class 缓存_基于数据库的缓存依赖 : System.Web.UI.Page
{
    protected void Page_Load(object sender,EventArgs e)
    {
        //ASPNETCaCheHelpers.CaCheHelper cache = new ASPNETCaCheHelpers.CaCheHelper();
        //cache.Cacheobj = Cache;
        //检查缓存是否为空
        if (Cache["newcache"] == null)
        {
            string filepath = Server.MapPath("Cache.txt");
            //缓存依赖对象
            sqlCacheDependency cachedependency = new sqlCacheDependency("GSMMS","T_Msg_CahceVersion");
            //添加缓存
            Cache.Add("newcache",GetMsg(),cachedependency,Cache.NoAbsoluteExpiration,Cache.NoSlidingExpiration,CacheItemPriority.Normal,CahceRemoveCallBack);
            //cache.AddDataBaseCacheDependency("newcache","GSMMS","T_Msg_CahceVersion",CahceRemoveCallBack);
            Response.Write(Cache["newcache"].ToString());
            label1.Text = "从数据库中取数据再存到缓存中";
        }
        else
        {
            Response.Write(Cache["newcache"].ToString());
            label1.Text = "直接从缓存中拿数据";
        }
    }
    //当缓存被删除时执行的方法(委托)
    private void CahceRemoveCallBack(string key,object value,CacheItemRemovedReason reason)
    {
        string filepath = Server.MapPath("CahceDataBaseDependency.txt");
        string msg = "缓存:" + key + "被删除了,因为:" + reason.ToString() + "\r\n";
        File.AppendAllText(filepath,msg);
    }
    private string GetMsg()
    {
        DataTable dt = sqlHelper_MSsql.sqlHelper.ExcuteDataTable("select * from T_Msg_CacheTest");
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < dt.Rows.Count; i++)
        {
            DataRow dr = dt.Rows[i];
            sb.Append("<div>标题:" + dr["title"].ToString() + "---内容:" + dr["contents"].ToString() + "--添加时间:" + dr["addtime"].ToString() + "</div>");
        }
        return sb.ToString();
    }
}

相关文章

适配器模式将一个类的接口转换成客户期望的另一个接口,使得原本接口不兼容的类可以相互合作。
策略模式定义了一系列算法族,并封装在类中,它们之间可以互相替换,此模式让算法的变化独立于使用算法...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,它是针对软件开发中经常遇到的一些设计问题...
模板方法模式在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中,使得子类可以在不改变算法结...
迭代器模式提供了一种方法,用于遍历集合对象中的元素,而又不暴露其内部的细节。
外观模式又叫门面模式,它提供了一个统一的(高层)接口,用来访问子系统中的一群接口,使得子系统更容...