.net2.0缓存小例测试

缓存是.net2.0引入的一个新东西,借助SqlCacheDependency(存在于System.Web.Cacheing下)可以添加缓存项对数据库表或查询的依赖,这个东西用在sql2005下可以不用设置因为sql2005已经提供了缓存依赖的条件,用在sql2000下用有两种办法都可以实现:

一.要对数据库进行下命令操作

使用aspnet_regsql命令行工具,aspnet_regsql工具位于Windows\Microsoft.NET\Framework\[版本]文件夹中,如果要配置SqlCacheDependency,则需要以命令行的方式执行。例如:
aspnet_regsql -S localhost -E -d test -ed  //test为数据库名称
aspnet_regsql -S localhost -E -d test -t news -et  //test为数据库名字,news为表名

二.或者使用SqlCacheDependencyAdmin类

方法一:
在web.config文件<configuration>节中添加:

<connectionStrings>
  <add name="testConn" connectionString="server=.;database=test;uid=sa;pwd="/>
 </connectionStrings>

在接下来的<system.web>节中添加缓存策略如下:
<caching >
      <sqlCacheDependency  enabled="true" pollTime="600000">
        <databases>
          <add name="test" connectionStringName="testConn" pollTime="600000"/>
        </databases>
      </sqlCacheDependency>
    </caching>
注意:这里的<add>中的name是必须的,是要添加到设置集合中的SqlCacheDependencyDatabase对象的名称,此名称用作 @ OutputCache 指令上 SqlDependency 属性的一部分。pollTime:设置 SqlCacheDependency 轮询数据库表以查看是否发生更改的频率(以毫秒计算)。

在aspx页面放一个GridView,代码文件可以如下:
protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            string key = "TableCache";
            DataSet data = (DataSet)HttpRuntime.Cache[key];

            if (data == null)
            {
                data = GetDataSource();
                AggregateCacheDependency cd = TableDependency();
                HttpRuntime.Cache.Add(key, data, cd, DateTime.Now.AddHours(1), System.Web.Caching.Cache.NoSlidingExpiration, CacheItemPriority.High, null);
            }
            this.GridView1.DataSource = data;
            this.GridView1.DataBind();
        }
    }

    private AggregateCacheDependency TableDependency()
    {
        AggregateCacheDependency dependency = new AggregateCacheDependency();
        dependency.Add(new SqlCacheDependency("test", "news"));
        return dependency;
    }
    private DataSet GetDataSource()
    {
        DataSet ds = SqlHelper.ExecuteDataset(CommandType.StoredProcedure, "GetAllNews");
        return ds;
    }


    protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
    {
        this.GridView1.PageIndex = e.NewPageIndex;
        this.GridView1.DataSource = GetDataSource();
        this.GridView1.DataBind();
    }

方法二:使用SqlCacheDependencyAdmin类,web.config文件配置和方法一一样

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            string key = "TableCache";
            DataSet data = (DataSet)HttpRuntime.Cache[key];

            if (data == null)
            {
                data = GetDataSource();
                //启用指定数据库的更改通知
                SqlCacheDependencyAdmin.EnableNotifications(ConfigurationManager.ConnectionStrings["testConn"].ConnectionString);
                //连接到sqlserver数据库并为SqlCacheDependency更改通知准备数据库表
                SqlCacheDependencyAdmin.EnableTableForNotifications(ConfigurationManager.ConnectionStrings["testConn"].ConnectionString, "news");
                //指定缓存策略
                SqlCacheDependency scd = new SqlCacheDependency("test", "news");
                //插入缓存
                HttpRuntime.Cache.Insert(key, data, scd);
            }
            this.GridView1.DataSource = data;
            this.GridView1.DataBind();
        }
    }

    private DataSet GetDataSource()
    {
        DataSet ds = SqlHelper.ExecuteDataset(CommandType.StoredProcedure, "GetAllNews");
        return ds;
    }

    protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
    {
        this.GridView1.PageIndex = e.NewPageIndex;
        this.GridView1.DataSource = GetDataSource();
        this.GridView1.DataBind();
    }

 

posted @ 2008-11-19 14:50  轻尘家园  阅读(271)  评论(0编辑  收藏  举报