版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
本文檔是VisualC#教程(切換到VisualBasic教程)最簡單的緩存策略就是使緩存數(shù)據(jù)在一個指定的時間周期后過期。但是這個簡單的方法意味著緩存數(shù)據(jù)沒有保持與底層數(shù)據(jù)源的聯(lián)系,從而導致過期數(shù)據(jù)長時保存或當前數(shù)據(jù)很快過期。更好的方法是使用SqlCacheDependency類,這樣數(shù)據(jù)一直被緩存,直到其底層數(shù)據(jù)在SQL數(shù)據(jù)庫中被修改。本篇教程將講解怎樣使用這個類。Part1簡介使用ObjectDataSource緩存數(shù)據(jù)和在架構中緩存數(shù)據(jù)教程中探討的緩存技術使用基于時間的有效期,在指定的周期過后從緩存中清除數(shù)據(jù)。該方法是平衡緩存性能與數(shù)據(jù)過時的最簡單的方法。選擇x秒的有效期,頁面開發(fā)者雖然只能享受到x秒的緩存帶來的好處,但可高枕無憂,因為數(shù)據(jù)的過期時間最多不會超過x秒。當然,對于靜態(tài)數(shù)據(jù),x可以延長為web應用程序的生命周期,如應用程序啟動時緩存數(shù)據(jù)教程所述。緩存數(shù)據(jù)庫數(shù)據(jù)時,人們常常會選用基于時間的有效期,因為其易于使用。但常常這不是個合適的方案。理想情況是:數(shù)據(jù)庫數(shù)據(jù)一直被緩存,直到底層數(shù)據(jù)在數(shù)據(jù)庫中被修改;此時才清除緩存。該方法能最大地獲得緩存帶來的性能上的好處,同時使過時數(shù)據(jù)保持的時間最短。然而,為享受到這些好處,必須建立一套系統(tǒng),該系統(tǒng)可以感知到底層數(shù)據(jù)庫數(shù)據(jù)發(fā)生了改變并從緩存中清除相應的條目。在ASP.NET2.0以前,頁面開發(fā)者負責實現(xiàn)該系統(tǒng)。ASP.NET2.0提供了SqlCacheDependency類以及必要的基礎架構,利用它們可以在數(shù)據(jù)庫發(fā)生了變化時感知到變化,從而清除相應的緩存條目。有兩種技術可用于感知底層數(shù)據(jù)發(fā)生的變化:通知和輪詢。下面我們會討論通知和輪詢的不同之處,之后,我們將創(chuàng)建必要的基礎架構來支持輪詢,然后探討怎樣通過聲明和編程兩種方式來使用SqlCacheDependency類。了解通知和輪詢有兩種技術可用于感知數(shù)據(jù)庫中的數(shù)據(jù)發(fā)生的變化:通知和輪詢。使用通知時,對于某個具體查詢,如果自其上次執(zhí)行以來其查詢結果已發(fā)生了改變,數(shù)據(jù)庫會自動通知ASP.NET運行時。使用輪詢時,數(shù)據(jù)庫服務器保存特定表最近發(fā)生更改時的信息。ASP.NET運行時周期性地查詢數(shù)據(jù)庫,看哪些表的數(shù)據(jù)在緩存后發(fā)生過改動。其數(shù)據(jù)改動過的那些表的相關緩存條目會被清除。選用通知技術時,需要的建立工作比輪詢少,并且具有更細的粒度,因為該技術在查詢級而不是在表級跟蹤變化。遺憾的是,只有在MicrosoftSQLServer2005的完整版,即非速成(non-Express)版中,才能使用通知。而對于MicrosoftSQLServer從7.0到2005之間的所有版本,都可采用輪詢技術。由于這些教程使用的是SQLServer2005Express版,我們將集中探討建立和使用輪詢。有關SQLServer2005的通知功能的更多資料,請參考本教程末尾的更多閱讀材料部分。采用輪詢時,需配置數(shù)據(jù)庫,使其包含一個名為AspNet_SqlCacheTablesForChangeNotification的表,該表有三列-tableName、notificationCreated和changeId。對于那些在web應用程序的SQL緩存依賴項中可能需要用到其數(shù)據(jù)的表,該表都有一條記錄與之對應。tableName列指定表名,而notificationCreated指示將該記錄添加到表中時的日期和時間。changeld列為int類型,其初始值為0。每次修改對應的表時,其值遞增。除了AspNet_SqlCacheTablesForChangeNotification表之外,數(shù)據(jù)庫還需要對可能出現(xiàn)在SQL緩存依賴項中的每個表包含一個觸發(fā)器。每當在AspNet_SqlCacheTablesForChangeNotification表中插入、更新、刪除一條記錄,或表中changeId值遞增時,會執(zhí)行這些觸發(fā)器。在使用一個SqlCacheDependency對象緩存數(shù)據(jù)時,ASP.NET運行時會跟蹤相應表的當前changeId。系統(tǒng)周期性地檢查數(shù)據(jù)庫,一旦發(fā)現(xiàn)某個SqlCacheDependency對象的changeId值不同于數(shù)據(jù)庫中的相應值,就清除該對象,因為changeId值不同意味著數(shù)據(jù)被緩存后相應表又有了變化。步驟1:探討aspnet_regsql.exe命令行程序如上所述,使用輪詢方法時,必須對數(shù)據(jù)庫進行設置,使其包含下面的基礎架構:一個預先定義的表(AspNet_SqlCacheTablesForChangeNotification),一些存儲過程,以及web應用程序中SQL緩存依賴項可能用到的各個表的觸發(fā)器。可通過命令行程序aspnet_regsql.exe來創(chuàng)建這些表、存儲過程和觸發(fā)器,該程序位于$WINDOWS$¥Microsoft.NET¥Framework¥version文件夾下。要創(chuàng)0建AspNet_SqlCacheTablesForChangeNotification表和相關的存儲過程,在命令行執(zhí)行以下命令:/*ForSQLServerauthentication...*/aspnet_regsql.exe-Sserver-Uuser-Ppassword-ddatabase-ed/*ForWindowsAuthentication...*/aspnet_regsql.exe-Sserver-E-ddatabase-ed注意:要執(zhí)行這些命令,指定的數(shù)據(jù)庫帳戶必須具有db_securityadmin和db_ddladmin身份。要了解aspnet_regsql.exe命令行程序發(fā)送給數(shù)據(jù)庫的T-SQL,請參閱此博客文章。例如,在Windows身份認證模式下,對MicrosoftSQLServer數(shù)據(jù)庫服務器ScottsServer上的數(shù)據(jù)庫pubs添加輪詢的基礎架構時,進入到相應的目錄后在命令行中輸入:aspnet_regsql.exe-SScottsServer-E-dpubs-ed完成數(shù)據(jù)庫級基礎架構的添加后,我們需要針對SQL緩存依賴項中要用到的那些表添加觸發(fā)器。再次使用aspnet_regsql.exe命令行程序,不過這次使用-t來指定表名,且將-ed替換為-et,如下:/*ForSQLServerauthentication...*/aspnet_regsql.exe-S<i>server</i>-U<i>user</i>-P<i>password</i>-d<i>database</i>-t<i>tableName</i>-et/*ForWindowsAuthentication...*/aspnet_regsql.exe-S<i>server</i>-E-d<i>database</i>-t<i>tableName</i>-et要對ScottsServer上的pubs數(shù)據(jù)庫中的authors和titles表添加觸發(fā)器,使用:aspnet_regsql.exe-SScottsServer-E-dpubs-tauthors-etaspnet_regsql.exe-SScottsServer-E-dpubs-ttitles-et對于本教程,要對Products、Categories和Suppliers表添加觸發(fā)器。我們將在步驟3中探討具體的命令行語句。步驟2:在App_Data中引用MicrosoftSQLServerExpress版數(shù)據(jù)庫在添加必要的輪詢基礎架構時,spnet_regsql.exe命令行程序需要數(shù)據(jù)庫和服務器的名稱。但是對于放在App_Data文件夾中的MicrosoftSQLServer2005Express數(shù)據(jù)庫而言,它的數(shù)據(jù)庫名和服務器名又是什么呢?沒有必要探究其數(shù)據(jù)庫名和服務器名到底是什么,我發(fā)現(xiàn)最簡單的方法是用SQLServerManagementStudio來將該數(shù)據(jù)庫附加到localhost¥SQLExpress數(shù)據(jù)庫實例,并重命名該數(shù)據(jù)庫。如果您在計算機上安裝了SQLServer2005的一個完整版,則很可能也安裝了SQLServerManagementStudio。如果您安裝的是Express版本,可以下載免費的MicrosoftSQLServerManagementStudioExpressEdition。首先,關閉VisualStudioo然后,打開SQLServerManagementStudio,選擇使用WindowsAuthentication連接到localhost¥SQLExpress服務器。圖1:連接到localhost¥SQLExpress服務器連接到服務器后,ManagementStudio將顯示該服務器,其中有針對數(shù)據(jù)庫、安全等的子文件夾。右鍵單擊Databases文件夾并選擇Attach選項。這將彈出AttachDatabases對話框(參見圖2)。單擊Add按鈕,選擇您的web應用程序的App_Data文件夾下的NORTHWND.MDF數(shù)據(jù)庫文件夾。圖2:附加App_Data文件夾下的NORTHWND.MDF數(shù)據(jù)庫這會將該數(shù)據(jù)庫添加到Databases文件夾。數(shù)據(jù)庫名可能是該數(shù)據(jù)庫文件的完整路徑或前面帶有一個GUID的完整路徑。為避免在使用aspnet_regsql.exe命令行工具時輸入該過長的數(shù)據(jù)庫名,可通過右鍵單擊剛附加的數(shù)據(jù)庫并選擇Rename將該數(shù)據(jù)庫重命名為一個更友好的名稱。我將該數(shù)據(jù)庫重命名為“DataTutorials”。圖3:將附加的數(shù)據(jù)庫重命名為更友好的名稱步驟3:對Northwind數(shù)據(jù)庫添加輪詢基礎架構現(xiàn)在我們已附加了App_Data文件夾下的NORTHWND.MDF數(shù)據(jù)庫,可以開始添加輪詢基礎架構了。假定您已將該數(shù)據(jù)庫重命名為“DataTutorials”,執(zhí)行如下四個命令:aspnet_regsql.exe-Slocalhost\SQLExpress-E-dDataTutorials-edaspnet_regsql.exe-Slocalhost\SQLExpress-E-dDataTutorials-tProducts-etaspnet_regsql.exe-Slocalhost¥SQLExpress-E-dDataTutorials-tCategories-etaspnet_regsql.exe-Slocalhost¥SQLExpress-E-dDataTutorials-tSuppliers-et執(zhí)行這四個命令之后,在ManagementStudio中右鍵單擊該數(shù)據(jù)庫名,進入Tasks子菜單,選擇Detach。然后關閉ManagementStudio,重新打開VisualStudio。重新打開VisualStudio后,在ServerExplorer中找到并展開該數(shù)據(jù)庫。其中,可看到一個新表(AspNet_SqlCacheTablesForChangeNotification)、一些新的存儲過程以及Products、Categories和Suppliers表的觸發(fā)器。圖4:數(shù)據(jù)庫現(xiàn)在包含必需的輪詢基礎架構步驟4:配置輪詢服務在數(shù)據(jù)庫中創(chuàng)建了所需的表、觸發(fā)器和存儲過程后,最后步驟是配置輪詢服務,為此,在Web.config中指定要使用的數(shù)據(jù)庫,以及輪詢頻率(單位為毫秒)。下面的標記代碼指定每隔1秒輪詢一次Northwind數(shù)據(jù)庫。<?xmlversion="1.0"?><configuration><connectionStrings><addname="NORTHWNDConnectionString"connectionString="DataSource=.¥SQLEXPRESS;AttachDbFilename=|DataDirectory|¥NORTHWND.MDF;IntegratedSecurity二True;UserInstance=True"providerName="System.Data.SqlClient"/></connectionStrings><system.web>...<!--ConfigurethepollingserviceusedforSQLcachedependencies--><caching><sqlCacheDependencyenabled="true"pollTime="1000"><databases><addname="NorthwindDB"connectionStringName="NORTHWNDConnectionString"/></databases></sqlCacheDependency></caching></system.web></configuration><add>元素中的name值(“NorthwindDB”)是一個易讀的名稱,它對應于一個具體的數(shù)據(jù)庫。使用SQL緩存依賴項時,我們需要引用此處定義的數(shù)據(jù)庫名稱以及緩存數(shù)據(jù)所依賴的表。在步驟6中,我們將看到怎樣使用SqlCacheDependency類通過編碼將SQL緩存依賴項與緩存數(shù)據(jù)相關聯(lián)。一旦建立了SQL緩存依賴項,輪詢系統(tǒng)將每隔pollTime毫秒連接到<databases>元素中定義的數(shù)據(jù)庫,并執(zhí)行AspNet_SqlCachePollingStoredProcedure存儲過程。該存儲過程是在步驟3中使用aspnet_regsql.exe命令行工具添加的,它會返回AspNet_SqlCacheTablesForChangeNotificationeturns表中每條記錄的tableName和changeId值。過時的SQL緩存依賴項會從緩存中清除。應在權衡性能和數(shù)據(jù)過時的基礎上設置pollTime。小的pollTime值雖然使對數(shù)據(jù)庫的請求次數(shù)增加,但能更快的將過時數(shù)據(jù)從緩存中清除。較大的pollTime值雖然減少了對數(shù)據(jù)庫的請求次數(shù),但增加了從后臺數(shù)據(jù)改變到清除相關緩存條目之間的延遲時間。還好,數(shù)據(jù)庫請求只是執(zhí)行一個簡單的存儲過程,該存儲過程只是從一個簡單的記錄數(shù)少的表返回不多的幾行。對您的應用程序試用一些不同的pollTime值,從中找出一個可平衡數(shù)據(jù)庫訪問和數(shù)據(jù)過時這兩者的理想值。允許的最小pollTime值為500。注意:上面的例子在<sqlCacheDependency>元素中指定了一個單一的pollTime,但您也可以隨意地在<add>元素中指定pollTime值。當您指定了多個數(shù)據(jù)庫且想為每個數(shù)據(jù)庫都指定一個輪詢頻率時,這樣做很有用。步驟5:通過聲明方式使用SQL緩存依賴項在步驟1到4中,我們探討了如何建立必需的數(shù)據(jù)庫基礎架構并配置輪詢系統(tǒng)。有了這個基礎架構后,現(xiàn)在我們可以通過編程或聲明技術,在添加條目到數(shù)據(jù)緩存時使用相關的SQL緩存依賴項。在本步驟中,我們將探討如何以聲明的方式使用SQL緩存依賴項。在步驟6中,我們將探討編程的方式。使用ObjectDataSource緩存數(shù)據(jù)教程探討了ObjectDataSource的聲明方式的緩存功能。只要簡單地將EnableCaching屬性設置為True,CacheDuration屬性設置為某個時間間隔,ObjectDataSource就會自動地以指定間隔緩存從其底層對象返回的數(shù)據(jù)。ObjectDataSource還可使用一個或多個SQL緩存依賴項。下面我們演示怎樣以聲明方式使用SQL緩存依賴項。打開Caching文件夾中的SqlCacheDependencies.aspx頁面,從Toolbox中將一個GridView控件拖放到設計器中。將該GridView的ID設置為ProductsDeclarative,從其智能標簽中選擇相應選項,將其綁定到一個名為ProductsDataSourceDeclarative的新ObjectDataSource。圖5:創(chuàng)建一個名為ProductsDataSourceDeclarative的新ObjectDataSource配置該ObjectDataSource使用ProductsBLL類,在SELECT選項卡的下拉列表中選擇GetProductsO。在UPDATE選項卡中,選擇有三個輸入?yún)?shù)-productName、unitPrice和productID的UpdateProduct重載方法。在INSERT和DELETE選項卡的下拉列表中選擇“(None)”。圖6:選擇有三個輸入?yún)?shù)的UpdateProduct重載方法圖7:在INSERT和DELETE選項卡的下拉列表中選擇"(None)”完成ConfigureDataSource向導后,VisualStudio將為每個數(shù)據(jù)字段在GridView中創(chuàng)建BoundField和CheckBoxField。將ProductName、CategoryName和UnitPrice之外的所有字段刪除,并按您的意愿格式化這些字段。在GridView的智能標簽中,選中EnablePaging、EnableSorting和EnableEditing復選框。VisualStudio會將ObjectDataSource的OldValuesParameterFormatString屬性設置為original」。}。為使GridView的編輯功能正常工作,要么從聲明語句中完全地刪除該屬性,要么將其設置為缺省值{0}。最后,在GridView上面添加一個LabelWeb控件,并將其ID屬性設置為ODSEvents,其EnableViewState屬性設置為False。完成這些改變后,頁面的聲明代碼應類似如下。注意,我對GridView的各字段的外觀進行了一些定制,這對于演示SQL緩存依賴項功能來說并不是必要的。<asp:LabelID="ODSEvents"runat="server"EnableViewState="False"/><asp:GridViewID="ProductsDeclarative"runat="server"AutoGenerateColumns="False"DataKeyNames="ProductIDDataSourcelD="ProductsDataSourceDeclarative"AllowPaging="True"AllowSorting="True"><Columns><asp:CommandFieldShowEditButton="True"/><asp:TemplateFieldHeaderText="Product"SortExpression="ProductName"><EditItemTemplate><asp:TextBoxID="ProductName"runat="server"Text='<%#Bind("ProductName")%>'/><asp:RequiredFieldValidatorID="RequiredFieldValidator1"ControlToValidate="ProductName"Display="Dynamic"ErrorMessage="Youmustprovideanamefortheproduct."SetFocusOnError="True"runat="server">*</asp:RequiredFieldValidator></EditItemTemplate><ItemTemplate><asp:LabelID="Label2"runat="server"Text='<%#Bind("ProductName")%>'/></ItemTemplate></asp:TemplateField><asp:BoundFieldDataField="CategoryName"HeaderText="Category"ReadOnly="True"SortExpression="CategoryName"/><asp:TemplateFieldHeaderText="Price"SortExpression="UnitPrice"><EditItemTemplate>$<asp:TextBoxID="UnitPrice"runat="server"Columns="8"Text='<%#Bind("UnitPrice","{0:N2}")%>'></asp:TextBox><asp:CompareValidatorID="CompareValidator1"runat="server"ControlToValidate="UnitPrice"ErrorMessage="Youmustenteravalidcurrencyvaluewithnocurrencysymbols.Also,thevaluemustbegreaterthanorequaltozero."Operator="GreaterThanEqual"SetFocusOnError="True"Type="Currency"Display="Dynamic"ValueToCompare="0">*</asp:CompareValidator></EditItemTemplate><ItemStyleHorizontalAlign="Right"/><ItemTemplate><asp:LabelID="Labell"runat="server"Text='<%#Bind("UnitPrice","{0:c}")%>'/></ItemTemplate></asp:TemplateField></Columns></asp:GridView><asp:ObjectDataSourceID="ProductsDataSourceDeclarative"runat="server"SelectMethod="GetProducts"TypeName="ProductsBLL"UpdateMethod="UpdateProduct"><UpdateParameters><asp:ParameterName="productName"Type="String"/><asp:ParameterName="unitPrice"Type="Decimal"/><asp:ParameterName="productID"Type="Int32"/></UpdateParameters></asp:ObjectDataSource>Part2接下來,為ObjectDataSource的Selecting事件創(chuàng)建一個事件處理器,并在其中添加如下代碼:larative_SelectingSelectingEventArgse)ventfired";我們知道,只有當ObjectDataSource從其底層對象獲取數(shù)據(jù)時,才會觸發(fā)它的Selecting事件。如果ObjectDataSource從自己的緩存中訪問數(shù)據(jù),則不會觸發(fā)該事件?,F(xiàn)在從瀏覽器訪問該頁面。由于我們還未實現(xiàn)緩存,每次對網(wǎng)格進行分頁、排序或編輯時,頁面都會顯示文本“Selectingeventfi「e如圖8所示。
圖8:每次對GridView進行分頁、編輯或排序時觸發(fā)ObjectDataSource的Selecting事件在使用ObjectDataSource緩存數(shù)據(jù)教程中講過,如果EnableCaching屬性設置為true,ObjectDataSource會將數(shù)據(jù)緩存,并在CacheDuration屬性指定的時間內維持緩存數(shù)據(jù)。ObjectDataSource還有一個SqlCacheDependency屬性,該屬性可以通過以下模式為緩存數(shù)據(jù)添加一個或多個SQL緩存依賴項:databaseName1:tableName1;databaseName2:tableName2;...其中,databaseName是Web.config中<add>元素的name屬性中指定的數(shù)據(jù)軍名,tableName為數(shù)據(jù)庫表名。例如,要創(chuàng)建這樣一^個ObjectDataSource,它使用基于Northwind的Products表的SQL緩存依賴項來緩存數(shù)據(jù),緩存數(shù)據(jù)的時間不限,我們需將ObjectDataSource的EnableCaching屬性設置為True,其SqlCacheDependency屬性設置為“NorthwindDB:Products”注意:可以同時使用SQL緩存依賴項和基于時間的有效期,方法是,將EnableCaching設置為True、CacheDuration設置為所需時間間隔、SqlCacheDependency設置為數(shù)據(jù)庫名和表名。不管是基于時間的有效期到期還是輪詢系統(tǒng)發(fā)現(xiàn)底層數(shù)據(jù)庫數(shù)據(jù)發(fā)生改變,ObjectDataSource都會清除其數(shù)據(jù)。SqlCacheDependencies.aspx頁面中的GridView顯示的數(shù)據(jù)來自兩張表-Products和Categories(產品的CategoryName字段通過JOINonCategories獲得)。因此,我們想指定兩個SQL緩存依賴項:“NorthwindDB:Products;NorthwindDB:Categories”(1)The,?(1)The,?SelectingEventFired"textisnotpresentasthedataisbeingservedfromthecachen(Ucb頑S dtfSQLCxlwDependencies 、S?rthWorkingwithDataTutoriah富《心UsingSQLCacheDependencies(2)TheProduct"ChaiTea”isUpdatedfromtheBasics.aspxpage?0?**-> ?::. C?,匕?C、g??ta>amw>?QeEditir>9^ndC>eletin9DatafromaGrklVMvfAOfiCSf1 CiwYmi[I1[10 ?TOU*9?血 a crwngI1?4-HWEJ1QtiEte3 AhmMSvhjc1212-WOEddTOM血Qtftlfl4 fhdf3577■??a"EAXOfiftlfi5 CMe*morv?c^oon^r<24?twin匚A!Mate CIO|iicrt>erry)212-BMJMrw?<>(3)ReturningtotheFirstPageinSqlCacheDependencies.aspxredisplaystheSefectingEventFired”textsincethecacheddatawasevictedwhentheProductstablewasupdatedinStep2圖9:配置ObjectDataSource支持緩存且使用基于Products和Categories的SQL緩存依賴項配置ObjectDataSource支持緩存后,通過瀏覽器再次訪問該頁面。首次訪問頁面時,會出現(xiàn)“Selectingeventfired”文本,但進行翻頁、排序或單擊Edit或Cancel按鈕時,該文本會消失。這是因為數(shù)據(jù)裝載至I]ObjectDataSource的緩存中后,它一直在那兒,直到Products或Categories表發(fā)生改變或通過GridView對數(shù)據(jù)進行了更新。翻頁顯示網(wǎng)格,此時"Selectingeventfired”沒有出現(xiàn)。接著,另外打開一個新的瀏覽器窗口并導航到Basics教程的編輯、插入和刪除部分中的Basics.aspx頁面(~/EditInsertDelete/Basics.aspx)。更新某產品的名稱或價格。然后,從第一個瀏覽器窗口查看另一個不同的數(shù)據(jù)頁、對網(wǎng)格進行排序或單擊某行的Edit按鈕。這次,"Selectingeventfired"又出現(xiàn)了,因為底層數(shù)據(jù)庫數(shù)據(jù)已更改(參見圖10)。如果該文本沒有出現(xiàn)稍等后重試。我們知道,輪詢服務每隔pollTime毫秒檢測一次Products表的變化,因此在底層數(shù)據(jù)的更新和緩存數(shù)據(jù)的清除之間有一個延遲。(1)The,?(1)The,?SelectingEventFired"textisnotpresentasthedataisbeingservedfromthecachen(Ucb頑S dtfSQLCxlwDependencies 、S?rthWorkingwithDataTutoriah富《心UsingSQLCacheDependencies(2)TheProduct"ChaiTea”isUpdatedfromtheBasics.aspxpage?0?**-> ?::. C?,匕?C、g??ta>amw>?QeEditir>9^ndC>eletin9DatafromaGrklVMvfAOfiCSf1 CiwYmi[I1[10 ?TOU*9?血 a crwngI1?4-HWEJ1QtiEte3 AhmMSvhjc1212-WOEddTOM血Qtftlfl4 fhdf3577■??a"EAXOfiftlfi5 CMe*morv?c^oon^r<24?twin匚A!Mate CIO|iicrt>erry)212-BMJMrw?<>(3)ReturningtotheFirstPageinSqlCacheDependencies.aspxredisplaystheSefectingEventFired”textsincethecacheddatawasevictedwhentheProductstablewasupdatedinStep2圖10:修改Products表會清除緩存的產品數(shù)據(jù)步驟6:通過編程方式使用SqlCacheDependency類在架構中緩存數(shù)據(jù)教程講述了在架構中使用一個單獨的緩存層的好處,這勝過了緩存功能與ObjectDataSource緊密結合的情況。在那個教程中,我門創(chuàng)建了一個ProductsCL類來演示怎樣以編程的方式進行數(shù)據(jù)緩存。要在緩存層使用SQL緩存依賴項,要使用SqlCacheDependency類。在輪詢系統(tǒng)中,一個SqlCacheDependency對象必須與某個具體的數(shù)據(jù)庫和表相關聯(lián)。例如,下面的代碼創(chuàng)建了一^基于Northwind數(shù)據(jù)庫的Products表的SqlCacheDependency對象:ableDependency=NorthwindDB”,"Products");SqlCacheDependency的構造函數(shù)的兩個輸入?yún)?shù)分別是數(shù)據(jù)庫名和表名。與ObjectDataSource的SqlCacheDependency屬性類似,使用的數(shù)據(jù)庫名是Web.config文件中<add>元素的name屬性指定的值。表名是實際的數(shù)據(jù)庫表名。要將一個SqlCacheDependency與一個添加到數(shù)據(jù)緩存中的條目相關聯(lián),可以使用一個接受依賴項的Insert重載方法。下面的代碼將value添加到數(shù)據(jù)緩存中,緩存時間不限,并將它基于Products表的SqlCacheDependency相關聯(lián)。換言之,value會一直保持在緩存中,直到由于內存不足或輪詢系統(tǒng)檢測到Products表在緩存后發(fā)生了改變才被清除。ableDependency=NorthwindDB","Products");,e.NoAbsoluteExpiration,e.NoSlidingExpiration);目前,緩存層的ProductsCL類緩存Products表的數(shù)據(jù),基于時間的有效期為60秒。我們對該類進行更新,使其使用SQL緩存依賴項。ProductsCL類的AddCacheltem方法負責將數(shù)據(jù)添加至I]緩存,目前它包含下面的代碼:Key,objectvalue)he=HttpRuntime.Cache;[0]isinthecache]=DateTime.Now;cy=newCaching.CacheDependency(null,MasterCachDataCache.Insert(GetCacheKey(rawKey),value,depDateTime.Now.AddSeconds(CacheDuration),System.Web.Caching.Cache.NoSlidingExpiration}更新該代碼,用一^個SqlCacheDependency對象來替換掉MasterCacheKeyArray緩存依賴項:Key,objectvalue)he=HttpRuntime.Cache;jectsforProductsctsTableDependency=cy("NorthwindDB","Products");eusingproductsTableDependencyDataCache.Insert(GetCacheKey(rawKey),value,proCaching.Cache.NoAbsoluteExpiration,Caching.}為了測試該功能,在頁面已有的ProductsDeclarativeGridView下面另外添加一個GridView。將該新GridView的ID設置為ProductsProgrammatic,通過其智能標簽將其綁定到一^新的名為ProductsDataSourceProgrammatic的ObjectDataSource。配置該ObjectDataSource使用ProductsCL類在SELECT和UPDATE選項卡的下拉列表中分別選擇GetProducts和UpdateProduct。
圖11:配置ObjectDataSource使用ProductsCL類
圖12:在SELECT選項卡的下拉列表中選擇GetProducts方法圖13:在UPDATE選項卡的下拉列表中選擇UpdateProduct方法完成ConfigureDataSource向導后,VisualStudio將為每個數(shù)據(jù)字段在GridView中創(chuàng)建BoundField和CheckBoxField。與添加到該頁的第一^個GridView一樣,將ProductName、CategoryName和UnitPrice之外的所有字段刪除,并按照您的意愿格式化這些字段。在GridView的智能標簽中,選中EnablePaging、EnableSorting和EnableEditing復選框。與ProductsDataSourceDeclarativeObjectDataSource一樣,VisualStudio會將ProductsDataSourceProgrammaticObjectDataSource的OldValuesParameterFormatString屬性設置為original_{0}。為使GridView的編輯功能正常工作,將該屬性置回{0}(或從聲明語句中完全地刪除該屬性賦值)。完成這些任務后,最終的GridView和ObjectDataSource聲明代碼類似如下:ic"runat="server"KeyNames="ProductID”Programmatic"AllowPaging="Truetton="True"/>t="Product"SortExpression="ProductName">ductName"runat="server"Text='<%#Bind("ProductName")%><asp:RequiredFieldValidatorID="RequControlToValidate="ProductName"ErrorMessage="YoumustprovideaSetFocusOnError="True"runat="server">*</asp:RequiredFi</EditItemTemplate><ItemTemplate><asp:LabelID="Label2"runat="serverText='<%#Bind("ProductName")%></ItemTemplate></asp:TemplateField><asp:BoundFieldDataField="CategoryName"HeaReadOnly="True"SortExpression="Category<asp:TemplateFieldHeaderText="Price"SortEx<EditItemTemplate>$<asp:TextBoxID="UnitPrice"runat="Text='<%#Bind("UnitPrice”,"{0:<asp:CompareValidatorID="CompareValControlToValidate="UnitPrice"DiErrorMessage="Youmustenteravnocurrencysymbols.Also,torequaltozero."Operator="GreaterThanEqual"SetFType="Currency"ValueToCompare="</EditItemTemplate><ItemStyleHorizontalAlign="Right"/><ItemTemplate><asp:LabelID="Label1"runat="serverText='<%#Bind("UnitPrice”,"{0:</ItemTemplate></asp:TemplateField></Columns></asp:GridView><asp:ObjectDataSourceID="ProductsDataSourceProgrammOldValuesParameterFormatString="{0}"SelectMethoTypeName="ProductsCL"UpdateMethod="UpdateProduc<UpdateParameters><asp:ParameterName="productName"Type="Stri<asp:ParameterName="unitPrice"Type="Decima<asp:ParameterName="productID"Type="Int32"</UpdateParameters></asp:ObjectDataSource>為測試緩存層中的SQL緩存依賴項,在ProductCL類的AddCacheltem方法中設置一個斷點,然后啟動調試。首次訪問SqlCacheDependencies.aspx時,會觸發(fā)斷點,因為是首次請求數(shù)據(jù),且數(shù)據(jù)會被放入緩存中。接下來,在GridView中跳轉到另一頁或對某個列進行排序。這會導致GridView查詢數(shù)據(jù),由于Products數(shù)據(jù)庫表尚未改動,會在緩存中找到數(shù)據(jù)。如果反復在緩存中找不到數(shù)據(jù),確保您機器上有足夠可用的內存,然后重試。在GridView里跳轉幾頁,打開另一個瀏覽器窗口,導航到Basics教程的編輯、插入和刪除部分中的Basics.aspx頁面(~/EditInsertDelete/Basics.aspx)。更新Products表的一條記錄,然后從第一個瀏覽器窗口查看一個新頁或單擊一個排序標題。此時,會遇到以下兩種情況之一:要么觸發(fā)斷點,這意味著緩存數(shù)據(jù)由于數(shù)據(jù)庫發(fā)生變化而被清除;要么不觸發(fā)斷點,意味著SqlCacheDependencies.aspx顯示的是過時的數(shù)據(jù)。如果沒有觸發(fā)斷點,很可能是由于數(shù)據(jù)變化后還未觸發(fā)輪詢服務。我們知道,輪詢服務每隔pollTime毫秒檢測一次Products表的變化,因此在底層數(shù)據(jù)的更新和緩存數(shù)據(jù)的清除之間有一個延遲。注意:通過SqlCacheDependencies.aspx中的GridView編輯某個產品時很可能會產生該延遲。在架構中緩存數(shù)據(jù)教程中,我們添加了MasterCacheKeyArray緩存依賴項以確保通過ProductsCL類的UpdateProduct方法編輯的數(shù)據(jù)會從緩存中清除。然而在本步驟開始時,我們在修改AddCacheItem方法時替換了該緩存依賴項,因此ProductsCL類會繼續(xù)顯示緩存的數(shù)據(jù),直到輪詢系統(tǒng)發(fā)現(xiàn)Products表的變化。我們將在步驟7中了解怎樣重新引入MasterCacheKeyArray緩存依賴項。步驟7:將一個緩存條目與多個依賴項相關聯(lián)我們知道,MasterCacheKeyArray緩存依賴項用于確保在緩存中與產品相關的所有條目中,只要其中一條的相關數(shù)據(jù)發(fā)生更改,所有與產品相關的數(shù)據(jù)都會從緩存清除。例如,GetProductsByCategorylDCategoryD)方法對每個獨特的categorylD值緩存多個ProductsDataTables實例。如果其中一個對象被清除,MasterCacheKeyArray緩存依賴項會確保其它對象也被清除。如果沒有該緩存依賴項,就會存在這種可能性,當緩存的數(shù)據(jù)被修改后,其它緩存的產品數(shù)據(jù)可能過時。因此,在使用SQL緩存依賴項的時候保持MasterCacheKeyArray緩存依賴項是很重要的。然而,數(shù)據(jù)緩存的Insert方法只允許一個依賴項對象。此外,在使用SQL緩存依賴項時,我們可能要依賴多個數(shù)據(jù)庫表。例如,在ProductsCL類中緩存的ProductsDataTable包含每個產品的分類名稱和供/
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023-2024學年山東省威海市高三(上)期末語文試卷
- 2024年浙教版選修1歷史上冊月考試卷含答案334
- 2022-2023年廣東省廣州市白云區(qū)六年級上冊期末英語試題及答案
- 2024年人教A版高一地理下冊月考試卷含答案278
- 二年級數(shù)學計算題專項練習1000題匯編集錦
- 貴州省遵義市2024-2025學年高一上學期12月月考地理試題
- 2024年度消防工程安裝與技術咨詢合同3篇
- 時尚鞋類產品的設計與創(chuàng)新考核試卷
- 四川省內江市威遠中學2024-2025學年高一上學期12月月考語文試題
- 第一單元混合運算(單元測試)-2024-2025學年三年級上冊數(shù)學北師大版
- 2024年同等學力英語考試真題及詳解
- CDASHStandards數(shù)據(jù)采集標準全版
- 初中地理學科學習新課標(2022版)考核試卷有答案
- 玻璃工業(yè)的節(jié)能減排與綠色制造
- 波士頓咨詢-X大型制造業(yè)數(shù)字化轉型戰(zhàn)略規(guī)劃項目(交付版)
- 紀法培訓課件
- 上海市浦東新區(qū)部分學校聯(lián)考2023-2024學年七年級上學期期末考試數(shù)學試題
- 南京理工大學物理化學課程考試8套卷(含答案)
- 泌尿外科工作總結及計劃
- 2023-2024學年度第一學期墻新學校小學部六年級課外閱讀答題活動
- 光伏發(fā)電項目現(xiàn)場安全檢查表(帶檢查依據(jù))
評論
0/150
提交評論