.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();
    }

 

转载于:https://www.cnblogs.com/qchome/archive/2008/11/19/1336686.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值