一,使數據庫支持SQL高速緩存依賴性。
二,使表支持SQL高速緩存依賴性。
三,在ASP.NET應用程序的web.config文件中包含SQL連接字符串。
四,以如下方式利用SQL高速緩存依賴性:
1)在代碼中編程創建一個SqlCacheDependency對象。
2)給OutputCache指令添加SqlCacheDependency屬性。
3)通過Response.AddCacheDependency給Response對象添加一SqlCacheDependency實例。
開啟高速緩存依賴性的參數簡要說明
-d <database> 用於SQL高速緩存依賴性的數據庫名。數據庫可以使用連接字符串和-c選項指定(必選)
-ed 允許數據庫啟用SQL高速緩存依賴性。
-dd 禁止數據庫啟用SQL高速緩存依賴性。
-et 允許表啟用SQL高速緩存依賴性。需要-t選項。
-dt 禁止表啟用SQL高速緩存依賴性。需要 -t 選項。
-t <table> 支持或禁止SQL高速緩存依賴性的表名。需要 -et 或 -dt 選項。
-lt 列出所有啟用SQL高速緩存依賴性的表。
在SQL Server 2000中使用高速緩存禁用功能(在2005中也可以進行如下設置)
要在SQL 2000中使用高速緩存禁用功能,必須執行如下兩步:
第一步是使相應的數據庫支持該功能。
第二步是使要使用的表支持該功能。
例:
aspnet_regsql -S localhost -U sa -P sa -d Northwind -ed
注:將本機上的Northwind數據庫開啟高速緩存依賴功能。
aspnet_regsql -S localhost -U sa -P sa -d Northwind -dd
注:禁用本機上的Northwind數據庫的高速緩存依賴功能。使用次命令後,數據庫中的所有表的高速緩存禁用功能都自動關閉,AspNet_SqlCacheTablesForChangeNotification表也會自動刪除。
開啟表的高速緩存依賴功能。
例:
aspnet_regsql -S localhost -U sa -P sa -d Northwind -t Products -et
注:為Northwind數據庫中的Products表開啟高速緩存依賴功能。
aspnet_regsql -S localhost -U sa -P sa -d Northwind -t Products -dt
注:為 Northwind數據庫中的Products表關閉高速緩存依賴功能。通過這個方法可以為一個數據庫中的一個或多個表開啟高速緩存依賴功能。為數據庫和表開啟高速緩存依賴功能後,可以發現Northwind數據庫中添加了一個 AspNet_SqlCacheTablesForChangeNotification表,表示配置成功了。
aspnet_regsql -S localhost -U sa -P sa -d Northwind -lt
使用-lt參數可以查看該數據庫中哪些表開啟了高速緩存依賴功能。如果數據庫關閉了高速緩存依賴或者沒有啟用高速緩存依賴功能,使用此命令將會得到錯誤提示。
關於SQL 2005的高速緩存禁用功能
SQL Server 2005支持高速緩存的編程和聲明技術。在OupputCache指令中使用CommandNotification字符串就可以給頁面建立基於通知的高速緩存。可以編程指定SQL高速緩存選項,或聲明該選項,但不能同時使用這兩種方法。SQL2005的緩存依賴無需web.config的配置,也不用為數據庫和表開啟緩存依賴功能,由於05內置了一個通知傳遞服務,該服務可以實現檢測數據的更改、實現更改通知傳遞等功能,因此不需要不斷輪詢數據庫來檢測數據更新了。
注:雖然05中的緩存依賴使用很簡單,但目前我還沒有找到更多的相關資料,還沒有親自進行測試,主要原因還沒搞清楚怎麼才能開啟Broker服務,以後有時間在進行測試吧。
配置ASP.NET應用程序
使用數據庫和其中的幾個表支持SQL Server高速緩存禁用功能後,就要為SQL Server高速緩存禁用功能配置應用程序。
要配置應用程序,以使用SQL Server高速緩存禁用功能,首先應修改web.config文件。在此文件中,指定要使用的數據庫,並讓ASP.NET連接它。
如:
<connectionStrings>
<add name="NorthwindConnectionString" connectionString="Data Source=.;Initial Catalog=Northwind;User ID=sa;Password=sa"
providerName="System.Data.SqlClient" />
</connectionStrings>
<system.web>
<caching>
<sqlCacheDependency enabled="true" pollTime="500">
<databases>
<clear/>
<add name="Northwind" connectionStringName ="NorthwindConnectionString" pollTime="500"/>
</databases>
</sqlCacheDependency>
</caching>
</system.web>
注:首先使用web.config文件中的<connectionStrings>元素,建立了與數據庫的連接字符串。然後通過<caching>元素為SQL Server高速緩存功能進行配置。要是使用SQL Server高速緩存依賴性,所以必須使用<sqlCacheDependency enabled="true">節點,並啟用該功能。在<databases>節點中引用數據庫。
<add>元素中的屬性說明:
name:為SQL Server數據庫提供一個標識符。
connectionStringName:指定連接的名稱。
pollTime:指定SQL Server輪流檢測的時間間隔,默認為5秒或500毫秒。SQL 2005通知功能不需要這個屬性。
web.config 文件配置正確後,就可以在頁面上使用SQL Server高速緩存禁用功能了。ASP.NET會把SQL Server請求放在AspNet_SqlCacheTablesForChangeNotification表的一個完全不同的線程上,看看 changeId號是否遞增了,如果該數字有變化,ASP.NET就知道對底層的SQL Server表進行了修改,應檢索一個新的結果集。它確定是否應進行SQL Server調用時,對AspNet_SqlCacheTablesForChangeNotification表的請求會得到一個結果,啟動了SQL Server高速緩存禁用功能後,這些執行得非常快。
為頁面添加多個表,如下(用分號隔開):
<%@ OutputCache Duration="3600" VaryByParam="none" SqlDependency="Northwind:Employees;Northwind:Customers" %>