亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

asp.net中SqlCacheDependency緩存技術概述

2024-07-10 13:28:03
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了asp.net中SqlCacheDependency緩存技術概述,是大型web程序設計中常用的技術,本文對此進行了較為詳細的描述,需要的朋友可以參考下
 
 

本文實例講述了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程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人一区在线| 美女av一区二区| 91系列在线观看| 亚洲精品自产拍| 国产亚洲欧美日韩精品| 91国产美女视频| 亚洲人成77777在线观看网| 国产精品嫩草影院久久久| 精品视频在线播放免| 中文字幕久久亚洲| 深夜福利亚洲导航| 中文字幕成人精品久久不卡| 91在线视频一区| 国产欧美一区二区白浆黑人| 亚洲女人天堂视频| 亚洲欧美精品伊人久久| 欧美国产日韩中文字幕在线| 日韩视频永久免费观看| 国产日韩欧美中文| 亚洲第一天堂av| 97在线视频免费看| 高清日韩电视剧大全免费播放在线观看| 91高清免费在线观看| 国产噜噜噜噜久久久久久久久| 综合网中文字幕| 中文字幕九色91在线| 一区二区三区黄色| 在线观看国产精品淫| 91在线观看免费| 午夜精品在线观看| 97视频在线观看网址| 精品视频中文字幕| 色哟哟亚洲精品一区二区| 97精品国产91久久久久久| 欧美亚洲另类视频| 26uuu另类亚洲欧美日本老年| 18一19gay欧美视频网站| 成人激情视频在线观看| 热草久综合在线| 日韩av日韩在线观看| 久久在线视频在线| 日本在线观看天堂男亚洲| 国产精品入口夜色视频大尺度| www.亚洲天堂| 高清欧美一区二区三区| 日韩在线视频播放| 国外色69视频在线观看| 亚洲国产成人精品电影| 成人精品视频久久久久| 亚洲国产成人91精品| 欧美日本精品在线| 亚洲国产精品99| 日韩精品在线看| 国模精品一区二区三区色天香| 日韩高清电影免费观看完整| 亚洲欧美另类中文字幕| 欧美中文字幕第一页| 欧美黑人巨大精品一区二区| 久久免费国产精品1| 成人黄色中文字幕| 久久中文字幕在线视频| 欧美精品国产精品日韩精品| 日韩欧美极品在线观看| 亚洲国产精彩中文乱码av在线播放| 亚洲免费中文字幕| 国产精品高清免费在线观看| 亚洲字幕在线观看| 伊人男人综合视频网| 欧美在线视频观看免费网站| 国产成人激情小视频| 成人免费观看49www在线观看| 精品国模在线视频| 国产成人高潮免费观看精品| 91亚洲精品一区二区| 精品久久在线播放| 久久久噜噜噜久噜久久| 国产日韩视频在线观看| 亚洲最大的av网站| 色www亚洲国产张柏芝| 欧美情侣性视频| 成人黄色免费片| 国产精品欧美激情在线播放| 色视频www在线播放国产成人| 欧美日韩国产精品一区二区三区四区| 久久久噜噜噜久久久| 91精品视频观看| 欧美激情第1页| 日韩高清电影免费观看完整| 超碰97人人做人人爱少妇| 欧美午夜性色大片在线观看| 欧美日韩国产专区| 亚洲欧美国产一本综合首页| 久久艳片www.17c.com| 欧美日韩色婷婷| 欧美日韩不卡合集视频| 国产精品美女久久久免费| 国产精品成人av性教育| 亚洲男人的天堂在线播放| 欧美在线亚洲在线| 青青草国产精品一区二区| 亚洲成avwww人| 欧美人交a欧美精品| 国产成人极品视频| 日韩美女免费视频| 欧美大片免费观看在线观看网站推荐| 亚洲欧美制服综合另类| 色综合久久精品亚洲国产| 欧美精品在线极品| 欧洲s码亚洲m码精品一区| 国产91精品青草社区| 精品视频一区在线视频| 欧美日韩国产精品一区二区不卡中文| 久久精品成人欧美大片古装| 日韩在线www| 欧美日韩国产成人高清视频| 啊v视频在线一区二区三区| 亚洲国产又黄又爽女人高潮的| 国产精品日日做人人爱| 91网在线免费观看| 26uuu另类亚洲欧美日本老年| 爽爽爽爽爽爽爽成人免费观看| 色悠久久久久综合先锋影音下载| 亚洲精品国产综合区久久久久久久| 日韩视频亚洲视频| 午夜精品久久久99热福利| 亚洲精品美女网站| 久久精品免费播放| 久久久97精品| 亚洲精品日韩激情在线电影| 国产精品h片在线播放| 日韩精品中文字幕有码专区| 91色视频在线导航| 亚洲一区二区三| 国自在线精品视频| 国精产品一区一区三区有限在线| 91久久久久久久久久| 精品二区三区线观看| 日韩一区在线视频| 在线看片第一页欧美| 国产精品十八以下禁看| 91精品久久久久久久久中文字幕| 久久精品国产91精品亚洲| 国内精品国产三级国产在线专| 欧美极品少妇xxxxⅹ免费视频| 亚洲国产欧美在线成人app| 久久6免费高清热精品| 国产日韩在线看片| 91久久精品日日躁夜夜躁国产| 精品国产自在精品国产浪潮| 欧美大荫蒂xxx| 日韩中文字幕在线视频播放| 日韩美女免费线视频| 日韩精品免费在线| 久久久www成人免费精品| 午夜精品www| 国内免费久久久久久久久久久| 高清欧美性猛交| 欧美孕妇孕交黑巨大网站| 日本高清不卡的在线| 日韩有码在线观看| 欧美激情中文网| 91亚洲国产成人久久精品网站| 97香蕉超级碰碰久久免费软件| 欧美性xxxx18|