佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > asp.net中SqlCacheDependency緩存技術(shù)概述

asp.net中SqlCacheDependency緩存技術(shù)概述

熱門標(biāo)簽:客戶服務(wù) 網(wǎng)站排名優(yōu)化 電銷業(yè)務(wù) 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 國(guó)美全國(guó)運(yùn)營(yíng)中心 百度AI接口 電商新玩法 人工智能

本文實(shí)例講述了asp.net中SqlCacheDependency緩存技術(shù),對(duì)于大型web程序設(shè)計(jì)來(lái)說(shuō)具有很高的實(shí)用價(jià)值。具體如下:

對(duì)于訪問(wèn)量大,但更新較少的網(wǎng)站中使用緩存技術(shù),可以大大提高運(yùn)行效率;加上.NET 2.0提供的緩存依賴機(jī)制,我們可以很方便的對(duì)緩存進(jìn)行管理更新;以下是本人學(xué)習(xí)的一點(diǎn)心得體會(huì),希望能夠起到拋磚引玉的作用。

建立緩存依賴,實(shí)現(xiàn)代碼如下:

/**//// summary> 
/// 建立緩存依賴項(xiàng) 
/// /summary> 
/// returns>/returns> 
private AggregateCacheDependency TableDependency() 
{ 
AggregateCacheDependency dependency = new AggregateCacheDependency(); 
dependency.Add(new SqlCacheDependency("MSPetShop4", "表名稱")); 

return dependency; 
} 

一個(gè)非常簡(jiǎn)單的方法,首先我們先看看兩個(gè).NET 2.0新增的兩個(gè)類:

AggregateCacheDependency在System.Web.Caching命名空間中,AggregateCacheDependency主要作用是用于組合 ASP.NET 應(yīng)用程序的 Cache 對(duì)象中存儲(chǔ)的項(xiàng)和 CacheDependency 對(duì)象的數(shù)組之間的多個(gè)依賴項(xiàng)。

SqlCacheDependency也存在于System.Web.Caching命名空間中,這個(gè)類用于建立ASP.NET應(yīng)用程序的Cache對(duì)象中存儲(chǔ)的項(xiàng)和特定SQL Server數(shù)據(jù)庫(kù)表之間的聯(lián)系。

SqlCacheDependency是如何建立Cache對(duì)象中存儲(chǔ)的項(xiàng)和特定SQL Server數(shù)據(jù)庫(kù)表之間的聯(lián)系的呢?看一下Web.Config配置文件就一目了然了。

?xml version="1.0"?> 
configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0"> 
connectionStrings> 
add name="LocalConnString" connectionString="Server=(Local);uid=sa;pwd=123456;DataBase=MSPetShop4"/> 
/connectionStrings> 
system.web> 
caching> 
sqlCacheDependency enabled="true" pollTime="10000"> 
databases> 
add name="MSPetShop4" connectionStringName="LocalConnString" pollTime="10000"/> 
/databases> 
/sqlCacheDependency> 
/caching> 
compilation debug="true"/> 
/system.web> 
/configuration> 

配置節(jié)databases>add name="MSPetShop4" connectionStringName="LocalConnString" pollTime="10000"/>/databases>中配置了數(shù)據(jù)庫(kù)信息,SqlCacheDependency類會(huì)自動(dòng)完成對(duì)此配置節(jié)信息的讀取以建立和數(shù)據(jù)庫(kù)之間的聯(lián)系。(注意)name="MSPetShop4"必須和new SqlCacheDependency("MSPetShop4", "表名稱")中的數(shù)據(jù)庫(kù)名稱相一致。更多的配置信息可以查看(MSDN幫助文檔)。

使數(shù)據(jù)庫(kù)支持SqlCacheDependency特性:

要使得7.0或者2000版本的SQL Server支持SqlCacheDependency特性,需要對(duì)數(shù)據(jù)庫(kù)服務(wù)器執(zhí)行相關(guān)的配置步驟。有兩種方法配置SQL Server:

使用aspnet_regsql命令行工具,或者使用SqlCacheDependencyAdmin類。

aspnet_regsql工具位于Windows\Microsoft.NET\Framework\[版本]文件夾中,如果要配置SqlCacheDependency,則需要以命令行的方式執(zhí)行。

以下是該工具的命令參數(shù)說(shuō)明:

-? 顯示該工具的幫助功能; 
-S 后接的參數(shù)為數(shù)據(jù)庫(kù)服務(wù)器的名稱或者IP地址; 
-U 后接的參數(shù)為數(shù)據(jù)庫(kù)的登陸用戶名; 
-P 后接的參數(shù)為數(shù)據(jù)庫(kù)的登陸密碼; 
-E 當(dāng)使用windows集成驗(yàn)證時(shí),使用該功能; 
-d 后接參數(shù)為對(duì)哪一個(gè)數(shù)據(jù)庫(kù)采用SqlCacheDependency功能; 
-t 后接參數(shù)為對(duì)哪一個(gè)表采用SqlCacheDependency功能; 
-ed 允許對(duì)數(shù)據(jù)庫(kù)使用SqlCacheDependency功能; 
-dd 禁止對(duì)數(shù)據(jù)庫(kù)采用SqlCacheDependency功能; 
-et 允許對(duì)數(shù)據(jù)表采用SqlCacheDependency功能; 
-dt 禁止對(duì)數(shù)據(jù)表采用SqlCacheDependency功能; 
-lt 列出當(dāng)前數(shù)據(jù)庫(kù)中有哪些表已經(jīng)采用sqlcachedependency功能。

比如在petshop4.0的數(shù)據(jù)庫(kù)中使用SqlCacheDependency特性:aspnet_regsql -S localhost -E -d MSPetShop4 -ed 
以上面的命令為例,說(shuō)明將對(duì)名為MSPetShop4的數(shù)據(jù)庫(kù)采用SqlCacheDependency功能,且SQL Server采用了windows集成驗(yàn)證方式。我們還可以對(duì)相關(guān)的數(shù)據(jù)表執(zhí)行aspnet_regsql命令,如:

aspnet_regsql -S localhost -E -d MSPetShop4 -t Item -et 
aspnet_regsql -S localhost -E -d MSPetShop4 -t Product -et 
aspnet_regsql -S localhost -E -d MSPetShop4 -t Category -et

最后為使用緩存:

protected void Page_Load(object sender, EventArgs e) 
{ 
if (!IsPostBack) 
{ 
string key = "TableCache"; //緩存名稱 
DataSet data = (DataSet)HttpRuntime.Cache[key]; //獲取緩存 

// 判斷緩存數(shù)據(jù)為空 
if (data == null) 
{ 
// 獲取數(shù)據(jù) 
data = GetDataSource(); 

// 創(chuàng)建緩存依賴 
AggregateCacheDependency cd = TableDependency(); 

// 創(chuàng)建緩存 
HttpRuntime.Cache.Add(key, data, cd, DateTime.Now.AddHours(1), Cache.NoSlidingExpiration, 

CacheItemPriority.High, null); 
} 

GridView1.DataSource = data; //綁定數(shù)據(jù) 
GridView1.DataBind(); 
} 
} 

獲取數(shù)據(jù)源的方法,結(jié)合實(shí)際使用做修改。

private DataSet GetDataSource() 
{ 
string ConnectionStringLocal = ConfigurationManager.ConnectionStrings["LocalConnString"].ConnectionString; 
SqlConnection connPubs = new SqlConnection(ConnectionStringLocal); 
SqlDataAdapter dad = new SqlDataAdapter("SELECT TOP 50 * FROM Product", connPubs); 
DataSet ds = new DataSet(); 
dad.Fill(ds); 
return ds; 
}

希望本文所述緩存技術(shù)對(duì)大家asp.net程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • Asp.Net Cache緩存使用代碼
  • ASP.net Substitution 頁(yè)面緩存而部分不緩存的實(shí)現(xiàn)方法
  • asp.net 客戶端瀏覽器緩存的Http頭介紹
  • asp.net(C#)遍歷memcached緩存對(duì)象
  • ASP.NET性能優(yōu)化之讓瀏覽器緩存動(dòng)態(tài)網(wǎng)頁(yè)的方法
  • ASP.NET網(wǎng)站管理系統(tǒng)退出 清除瀏覽器緩存,Session的代碼
  • ASP.NET緩存管理的幾種方法
  • C#緩存之SqlCacheDependency用法實(shí)例總結(jié)
  • asp.net頁(yè)面SqlCacheDependency緩存實(shí)例
  • 在ASP.NET 2.0中操作數(shù)據(jù)之五十九:使用SQL緩存依賴項(xiàng)SqlCacheDependency

標(biāo)簽:咸寧 拉薩 攀枝花 南平 益陽(yáng) 廈門 棗莊 POS機(jī)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中SqlCacheDependency緩存技術(shù)概述》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    濮阳县| 舒城县| 从化市| 淮滨县| 伊宁市| 乌拉特前旗| 和政县| 阜平县| 通州市| 日照市| 平舆县| 建瓯市| 永泰县| 新泰市| 仲巴县| 奎屯市| 凌云县| 大余县| 邹城市| 稻城县| 竹山县| 巴青县| 河源市| 上饶市| 东阳市| 从江县| 资溪县| 曲沃县| 绩溪县| 沧源| 灯塔市| 宜丰县| 慈利县| 凤冈县| 怀安县| 武隆县| 陆川县| 玉林市| 苗栗市| 临城县| 白玉县|