asp.net的缓存机制

缓存是把应用程序中的需要频繁、快速访问的数据保存在内存中的编程技术,通常用来提高网络的响应速度。在ASP.NET中使用Cache类来管理缓存。下面详述控件级数据缓存功能和页面级数据缓存功能的实现:

(1)数据库缓存依赖

数据库缓存依赖由SqlCacheDependency类管理;

数据库缓存依赖的优点:

1、提高数据呈现速度,每次获取数据后,系统根据用户设置的缓存时间,在有效期内,将数据保存在本地,用户请求数据结果时,系统不是从数据库中获取,而是直接从本地获取,从而提高了数据的获取速度。

2、单独缓存页面中的某一控件,而不影响其他数据的变化。为了保证页面中数据的准确性,通常只需要缓存数据控件,其他控件的数据时随时变化的。

3、数据便发生更改时,自动删除缓存项,并向Cache中添加新版本的项,这是数据库缓存依赖最重要的一个特点。

4、与SQL缓存依赖项关联的数据库操作比较简单,不会给服务器带来很高的处理成本。


--------------------------------------------------------------------------------

实例:

(1)开启页面调试功能:

新建一个网站,点击调试(或按F5),跳出“未启用调试对话框”,默认点击“确定”(不跳出对话框则作罢)。关闭空白网页,可以看到解决资源管理器出现了web配置文件,打开,在“System.web”节点下,添加开启数据库缓存依赖的代码如下:

view plaincopy to clipboardprint?
<caching> 
    <sqlCacheDependency enabled="true" pollTime="1000"> 
                  
    </sqlCacheDependency> 
</caching> 
<caching>
 <sqlCacheDependency enabled="true" pollTime="1000">
    
 </sqlCacheDependency>
</caching>

其中:enabled属性表示是否开启数据库缓存依赖;polltime属性表示轮询数据库表的更改频率,单位:ms;不能设置小于500ms;

(2)配置缓存依赖的数据库

为保证数据库发生变化,应用程序能够及时更新缓存版本,必须在配置文件中指明程序所依赖的数据库,配置如下:

在web.config文件的“configuration”节点下,添加如下代码:

view plaincopy to clipboardprint?
<connectionStrings>  
        <remove name="JWInfoConnectionString"/>  
        <add name="JWInfoConnectionString" connectionString="Data Source=.;   
            Initial Catalog=JWInfo; uid=sa; pwd=123456;"  
                            providerName="System.Data.SqlClient"/>  
</connectionStrings> 
<connectionStrings>
  <remove name="JWInfoConnectionString"/>
  <add name="JWInfoConnectionString" connectionString="Data Source=.;
   Initial Catalog=JWInfo; uid=sa; pwd=123456;"
                            providerName="System.Data.SqlClient"/>
</connectionStrings>

配置完数据库连接后,在启用数据库缓存依赖的配置中添加如下代码:

view plaincopy to clipboardprint?
<databases> 
    <add connectionStringName="JWInfoConnectionString" name="JWInfo" pollTime="1000"/> 
</databases> 
<databases>
 <add connectionStringName="JWInfoConnectionString" name="JWInfo" pollTime="1000"/>
</databases>

注:为防止途中出现错误,请按F5运行程序;

(3)为SQL SERVER启用缓存通知:

必须配置SQL SERVER才能就依赖数据中的更改向asp.ne提供合适的通知。

启用VS2005命令行(开始->程序->vs2005->vs2005 Tools->vs2005命令提示,进入DOS界面)输入:aspnet_regsql.exe,出现配置向导,进行配置;

注:为防止途中出现错误,请按F5运行程序;


--------------------------------------------------------------------------------

控件级数据缓存功能:

源文件:

view plaincopy to clipboardprint?
<form id="form1" runat="server"> 
      <table> 
        <tr> 
          <td style="width: 362px"> 
            当前时间:  
              <asp:Literal ID="Literal1" runat="server"></asp:Literal> 
          </td> 
        </tr> 
        <tr> 
          <td style="width: 362px"> 
            最后缓存时间:  
              <asp:Literal ID="Literal2" runat="server"></asp:Literal> 
          </td> 
        </tr> 
        <tr> 
          <td style="width: 362px; height: 213px"> 
              <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px"> 
                  <Columns> 
                      <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" /> 
                      <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" /> 
                      <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" /> 
                      <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" /> 
                  </Columns> 
              </asp:GridView> 
              <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>" 
                  SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]" 
                  CacheDuration="30" EnableCaching="true" OnSelected="SqlDataSource_Selected"></asp:SqlDataSource> 
          </td> 
        </tr> 
      </table> 
    </form> 
<form id="form1" runat="server">
      <table>
        <tr>
          <td style="width: 362px">
            当前时间:
              <asp:Literal ID="Literal1" runat="server"></asp:Literal>
          </td>
        </tr>
        <tr>
          <td style="width: 362px">
            最后缓存时间:
              <asp:Literal ID="Literal2" runat="server"></asp:Literal>
          </td>
        </tr>
        <tr>
          <td style="width: 362px; height: 213px">
              <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px">
                  <Columns>
                      <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" />
                      <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" />
                      <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" />
                      <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" />
                  </Columns>
              </asp:GridView>
              <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>"
                  SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]"
                  CacheDuration="30" EnableCaching="true" OnSelected="SqlDataSource_Selected"></asp:SqlDataSource>
          </td>
        </tr>
      </table>
    </form>

其中:CacheDuration表示缓存数据时间,单位:s,EnableCaching:表示在此数据源中是否启用缓存设置。OnSelected属性表示重新获取数据时的事件;

cs文件:

view plaincopy to clipboardprint?
protected void Page_Load(object sender, EventArgs e)  
    {  
        //获取当前时间  
        Literal1.Text = DateTime.Now.ToString();  
 
        //判断是否已经有缓存时间  
        if (Cache["LastAccess"] != null)  
        {  
            //获取当初的缓存时间  
            Literal2.Text = Cache["LastAccess"].ToString();  
        }  
    }  
    protected void SqlDataSource_Selected(object sender, SqlDataSourceStatusEventArgs e)  
    {  
        //当重新获取数据时,显示当前时间  
        Literal2.Text = DateTime.Now.ToString();  
        //进行时间戳的缓存  
        Cache["LastAccess"] = System.DateTime.Now.ToString();  
    } 
protected void Page_Load(object sender, EventArgs e)
    {
        //获取当前时间
        Literal1.Text = DateTime.Now.ToString();

        //判断是否已经有缓存时间
        if (Cache["LastAccess"] != null)
        {
            //获取当初的缓存时间
            Literal2.Text = Cache["LastAccess"].ToString();
        }
    }
    protected void SqlDataSource_Selected(object sender, SqlDataSourceStatusEventArgs e)
    {
        //当重新获取数据时,显示当前时间
        Literal2.Text = DateTime.Now.ToString();
        //进行时间戳的缓存
        Cache["LastAccess"] = System.DateTime.Now.ToString();
    }

点击“调试”运行,重复按F5,可看到效果;也可在数据有效期内修改数据库中数据观察效果;


--------------------------------------------------------------------------------

页面级数据缓存依赖功能:


页面缓存属性在HTML代码中配置,如下:(整个页面第二行)

<%@ OutputCache Duration="20" VaryByParam="None" %>

 

其余,源文件几乎与上一个示例相同,只是去掉sqlDataSource1中的控件级缓存属性,因为这里实现的是页面缓存功能;

如下:

view plaincopy to clipboardprint?
<form id="form1" runat="server"> 
      <table> 
        <tr> 
          <td style="width: 362px"> 
            当前时间:  
              <asp:Literal ID="Literal1" runat="server"></asp:Literal> 
          </td> 
        </tr> 
        <tr> 
          <td style="width: 362px"> 
            最后缓存时间:  
              <asp:Literal ID="Literal2" runat="server"></asp:Literal> 
          </td> 
        </tr> 
        <tr> 
          <td style="width: 362px; height: 213px"> 
              <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px"> 
                  <Columns> 
                      <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" /> 
                      <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" /> 
                      <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" /> 
                      <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" /> 
                  </Columns> 
              </asp:GridView> 
              <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>" 
                  SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]" OnSelected="SqlDataSource1_Selected"></asp:SqlDataSource> 
          </td> 
        </tr> 
      </table> 
    </form> 
<form id="form1" runat="server">
      <table>
        <tr>
          <td style="width: 362px">
            当前时间:
              <asp:Literal ID="Literal1" runat="server"></asp:Literal>
          </td>
        </tr>
        <tr>
          <td style="width: 362px">
            最后缓存时间:
              <asp:Literal ID="Literal2" runat="server"></asp:Literal>
          </td>
        </tr>
        <tr>
          <td style="width: 362px; height: 213px">
              <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px">
                  <Columns>
                      <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" />
                      <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" />
                      <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" />
                      <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" />
                  </Columns>
              </asp:GridView>
              <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>"
                  SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]" OnSelected="SqlDataSource1_Selected"></asp:SqlDataSource>
          </td>
        </tr>
      </table>
    </form>

.cs文件:

同上一个实例的cs文件,无需改动;

 

点击“调试”运行,重复按F5,可看到效果;也可在数据有效期内修改数据库中数据观察效果;

 

所谓“依赖”:指一方发生变化后,另一方也不得不变化,这样才保证数据库中的数据和页面上显示的数据一致、同步。

实际情况可将两种机制联合使用,使页面加载速度增快!

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值