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

asp.net中SqlCacheDependency緩存技術概述

本文實例講述了ASP.NET中SqlCacheDependency緩存技術,對于大型web程序設計來說具有很高的實用價值。具體如下:

對于訪問量大,但更新較少的網站中使用緩存技術,可以大大提高運行效率;加上.NET 2.0提供的緩存依賴機制,我們可以很方便的對緩存進行管理更新;以下是本人學習的一點心得體會,希望能夠起到拋磚引玉的作用。

建立緩存依賴,實現代碼如下:

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

一個非常簡單的方法,首先我們先看看兩個.NET 2.0新增的兩個類:

AggregateCacheDependency在System.Web.Caching命名空間中,AggregateCacheDependency主要作用是用于組合 ASP.NET 應用程序的 Cache 對象中存儲的項和 CacheDependency 對象的數組之間的多個依賴項。

SqlCacheDependency也存在于System.Web.Caching命名空間中,這個類用于建立ASP.NET應用程序的Cache對象中存儲的項和特定SQL Server數據庫表之間的聯系。

SqlCacheDependency是如何建立Cache對象中存儲的項和特定SQL Server數據庫表之間的聯系的呢?看一下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> 

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

使數據庫支持SqlCacheDependency特性:

要使得7.0或者2000版本的SQL Server支持SqlCacheDependency特性,需要對數據庫服務器執行相關的配置步驟。有兩種方法配置SQL Server:

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

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

以下是該工具的命令參數說明:

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

比如在petshop4.0的數據庫中使用SqlCacheDependency特性:ASPNET_regsql -S localhost -E -d MSPetShop4 -ed 
以上面的命令為例,說明將對名為MSPetShop4的數據庫采用SqlCacheDependency功能,且SQL Server采用了windows集成驗證方式。我們還可以對相關的數據表執行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]; //獲取緩存 // 判斷緩存數據為空 if (data == null) { // 獲取數據 data = GetDataSource(); // 創建緩存依賴 AggregateCacheDependency cd = TableDependency(); // 創建緩存 HttpRuntime.Cache.Add(key, data, cd, DateTime.Now.AddHours(1), Cache.NoSlidingExpiration, CacheItemPriority.High, null); } GridView1.DataSource = data; //綁定數據 GridView1.DataBind(); } } 

獲取數據源的方法,結合實際使用做修改。

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; }

希望本文所述緩存技術對大家ASP.NET程序設計有所幫助。

AspNet技術asp.net中SqlCacheDependency緩存技術概述,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 蜜桃成熟时2在线观看完整版hd | 欧美丰满熟妇BBB久久久 | 国产a视频视卡在线 | 成人免费视频在线 | 欧美日韩另类在线观看视频 | 成人网站国产在线视频内射视频 | 日本护士性生活 | 性色AV一区二区三区咪爱四虎 | 99久久精品费精品蜜臀AV | 高H辣肉办公室 | 叔叔 电影完整版免费观看韩国 | 吃春药后的女教师 | 国产永不无码精品AV永久 | 大学生第一次破女在线观看 | 99免费在线观看视频 | 欧美激情精品久久久久久不卡 | 国产在线观看免费观看不卡 | 国产一区二区青青精品久久 | 国产99RE在线观看69热 | 九九电影伦理片 | 99精品影院 | 月夜直播免费看 | 亚洲欧美综合中文字幕 | 午夜精品国产自在现线拍 | 亚洲人成7777| 中文字幕在线观看国产 | 同居了嫂子在线观看 | 亚洲欧美精品无码大片在线观看 | 一本道高清到手机在线 | 亚洲欧美强伦一区二区另类 | 久久99re2在线视频精品 | 久久视频在线视频观看天天看视频 | 果冻传媒在线完整免费播放 | 无人区国产片 | 久久久久久久久性潮 | 国产精品久久久久久久久久久 | 成人免费无毒在线观看网站 | 久久精品中文字幕免费 | 超碰97 总站 中文字幕 | 久久麻豆亚洲AV成人无码国产 | 欧美四虎精品二区免费 |