天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

本文實(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ì)有所幫助。

AspNet技術(shù)asp.net中SqlCacheDependency緩存技術(shù)概述,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线观看免费国产成人软件 | 亚洲AV成人片色在线观看网站 | 99国产小视频 | 99久久99久久久99精品齐 | 3D动漫网站HOXXXxes | 超碰在线视频人人AV | 亚洲天堂久久久 | 国产精品成人不卡在线观看 | 欧美日韩中文国产一区 | 九九九九九热 | 日本中文字幕巨大的乳专区 | 玩弄放荡人妻一区二区三区 | 毛片TV网站无套内射TV网站 | 韩国污动漫无遮掩无删减电脑版 | 把腿张开再深点好爽宝贝 | BL全肉多攻NP高H | 亚洲免费无l码中文在线视频 | 99精品国产免费观看视频 | 成人国内精品久久久久影 | 一边啪啪的一边呻吟声口述 | 日本粉嫩学生毛绒绒 | 翁止熄痒禁伦短文合集免费视频 | 欧美最猛黑人XXXXWWW | 亚洲国产成人久久精品影视 | 国产国产乱老熟女视频网站97 | 四虎精品久久 | YY6080A旧里番在线观看 | 久久橹 | 国产日韩高清一区二区三区 | 亚洲人成77777在线视频 | 精品一品国产午夜福利视频 | 看了n遍舍不得删的黄文 | 伊人国产在线视频 | 蜜芽最新域名解析网站 | 久久热在线视频精品 | 久久精品WWW人人爽人人 | 东热rq大乱交 | 俄罗斯破处 | 国产精品一区二区资源 | 久久人妻少妇嫩草AV蜜桃99 | 秀婷程仪公欲息肉婷在线观看 |