缓存整个页面
<%@ 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>