缓存的使用

原创 2007年10月14日 16:35:00

缓存整个页面

<%@ OutputCache Duration="30" VaryByParam="none" %> 

根据指定参数缓存页面

<%@ OutputCache Duration="30" VaryByParam="参数名" %> 

硬盘缓存

<%@ OutputCache Duration="3000" VaryByParam="none" DiskCacheable="true" %>

硬盘缓存一般用于保存大数据量的对象 且不会经常被访问的数据 因为频繁的从硬盘上读取文件会使性能反而降低

回调缓存

若希望页面部分代码不被缓存可以使用控件<asp:Substitution ID="Substitution1" runat="server" MethodName="ReturnDate" />方法必须声明为static 且必须传参HttpContext

sql数据缓存

三个步骤:
1.需要使用aspnet_regsql命令行或者SqlCacheDepencyAdmmin类配置数据库。目的是启用数据库对SQL数据缓存依赖功能的支持。

adpnet_regsql命令行的功能是完成有关数据库连接、应用服务、SQL数据缓存以来、会话状态等方面的配置。主要用来实现两项任务:
一是启用指定数据库的SQL数据库缓存依赖功能。aspnet_regsql -S ZGQ -U sa -P sa -d pubs -ed

二是启用指定表的SQL数据缓存依赖功能。aspnet_regsql -S ZGQ -U sa -P sa -d pubs -t titles -et
 
这两项配置完成后在数据库中回新建一个名为“AspNet_SqlCacheTablesForChangeNotification”表。它是启用了指定数据库的数据缓存依赖后,自动创建的数据表。该表用于记录在数据库中,启用了数据缓存依赖的数据表数据被更新的概况信息。表中有三个数据列。列tableName用于存储被更新的数据表的名称,(这些表必须启用了SQL数据缓存依赖);列notifacationCreated是用于存储数据表被更新的时间;列changeid是每当所跟踪数据表的数据发生变化时,这个字段的值就加一。ASPNET将依靠changeid的数据来决定是继续使用缓存中的数据对象还是进行更新操作。另外在数据库中还增加了几个数据存储过程、角色、触发器等。这些都是SQL数据缓存依赖功能而自动生成的。

获取当前数据库中启用SQL数据缓存以来功能的数据表列表。
aspnet_regsql -s ZGQ -U sa -P sa -d pubs -lt

关闭数据库的数据缓存依赖功能
aspnet_regsql -s ZGQ -U sa -P sa -d pubs -dd

关闭数据表的数据缓存依赖功能
aspnet_regsql -s ZGQ -U sa -P sa -d pubs -t titles -dt 

也可以使用SqlCacheDepencyAdmmin类配置数据库实现SQL缓存依赖功能

建议在Global.ascx文件中使用SqlCacheDepencyAdmin类实现对SQL缓存依赖功能的统一管理:
<%@ Application Language="C#" %>
<%@ Import Namespace="System.Configuration" %>
<%@ Import Namespace="System.Web.Caching" %>

<script runat="server">

    void Application_Start(object sender, EventArgs e)
    {
        // 在应用程序启动时运行的代码
        //以下实现的是启用数据库和数据库表的缓存依赖功能
        //如果登陆用户不具有管理pubs数据库的权限,将发生异常
        //获取连接字符串
        string connectionString = ConfigurationManager.ConnectionStrings["SQLCONNECTIONSTRING"].ConnectionString;
       
        //变量needToInstall指示是否需要起用数据缓存依赖功能
        bool needToInstall = true;
        try
        {
            //获取数据库中已经具有数据缓存依赖功能的数据表名称列表
            string[] tables = SqlCacheDependencyAdmin.GetTablesEnabledForNotifications(connectionString);

            if (tables != null)
            {
                foreach (string table in tables)
                {
                    //如果已经包含准备设置缓存依赖的表,设置needToInstall值为false
                    if(table.ToLower().Equals("titles"))
                    {
                        needToInstall = false;
                       
                    }
                }
            }

        }
        catch (Exception ex)
        {
            needToInstall = true;
           
        }

        //如果变量needToInstall值为true,则启用数据库pubs和数据库表titles的缓存依赖功能。
        if (needToInstall)
        {
            try
            {
                //启用数据库pubs的数据缓存依赖功能
                SqlCacheDependencyAdmin.EnableNotifications(connectionString);
               
                //启用数据库表titles的数据缓存依赖功能
                SqlCacheDependencyAdmin.DisableTableForNotifications(connectionString, "titles");

            }
            catch (Exception ex)
            {
               
            }
           
        }

    }
   
    void Application_End(object sender, EventArgs e)
    {
        //  在应用程序关闭时运行的代码

    }
       
    void Application_Error(object sender, EventArgs e)
    {
        // 在出现未处理的错误时运行的代码

    }

    void Session_Start(object sender, EventArgs e)
    {
        // 在新会话启动时运行的代码

    }

    void Session_End(object sender, EventArgs e)
    {
        // 在会话结束时运行的代码。
        // 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
        // InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer
        // 或 SQLServer,则不会引发该事件。

    }
      
</script>

CheckBox+ListView混合使用,并缓存

  • 2018年01月15日 16:26
  • 365KB
  • 下载

sql server 缓存依赖

  • 2009年05月15日 00:42
  • 83KB
  • 下载

缓存使用中的注意事项

达人科技 2016-12-09 08:58 一、缓存穿透 缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个不...
  • u011277123
  • u011277123
  • 2016-12-12 08:38:15
  • 410

java中缓存的使用

这里的缓存并不是指高速缓存cache,实际上是将一些缓存数据保留在主内存中,当需要访问的时候可以快速从中获取。储存在主内存中,相对于IO操作读写文件或者数据库,性能会提高很多。 注:将数据存储在本地...
  • qq_21033663
  • qq_21033663
  • 2016-04-03 10:56:32
  • 1039

Exchange的缓存模式有什么用?

在我们配置Outlook的exchange模式的时候,你看到你的默认投递位置了吗?一般管理严格的公司,默认投递位置都是:mailbox-username,这个就代表你是直接连接的服务器上面的邮箱,所有...
  • kepa520
  • kepa520
  • 2015-07-25 10:42:38
  • 2556

mybatis缓存的使用

mybatis缓存useCache的使用.
  • chenshuaining
  • chenshuaining
  • 2015-10-27 11:40:20
  • 2726

使用redis进行缓存

前台系统访问后台管理系统,如果要使用缓存,那么缓存逻辑一定放在后台系统。且要放在业务层。 当使用redis缓存时,要注意,在业务代码(service类)中,首先先从redis中去获取,然后return...
  • u011302734
  • u011302734
  • 2017-07-27 11:16:36
  • 1196

smarty缓存部分参考

  • 2010年02月25日 14:00
  • 6KB
  • 下载

springboot下及其方便的使用缓存

缓存的提供商是:ehcache只需要很少的代码就能实现缓存.1 开启spring缓存 @EnableCaching public class XxxxApplication extends Spr...
  • jessicway
  • jessicway
  • 2017-11-19 21:31:09
  • 343

浅谈缓存的使用

前几天一直在研究缓存的使用,一直对缓存的使用搞的不太清楚,现在找到了一篇比较好的介绍缓存的内容,系统的来解释一下缓存的定义以及缓存的简单的使用   1. 缓存概述 使用缓存可以避...
  • gengyudan
  • gengyudan
  • 2013-06-24 15:18:37
  • 4768
收藏助手
不良信息举报
您举报文章:缓存的使用
举报原因:
原因补充:

(最多只允许输入30个字)