明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

ASP.NET 2.0數(shù)據(jù)緩存技巧簡介

[摘要]在ASP.NET 2.0,新增加了不少新的功能和控件。其中,在數(shù)據(jù)的緩存功能,比asp.net 1.1有了很大的改變。眾所周知,數(shù)據(jù)的緩存功能是十分重要的,我們可以把一些在相對一段時(shí)間內(nèi)不發(fā)生改變的數(shù)據(jù)放在緩存中,這樣,就不必要每次去讀取數(shù)據(jù)庫,當(dāng)下次再需要這些數(shù)據(jù)時(shí),可以直接從緩存中取得,大大增...
在ASP.NET 2.0,新增加了不少新的功能和控件。其中,在數(shù)據(jù)的緩存功能,比asp.net 1.1有了很大的改變。眾所周知,數(shù)據(jù)的緩存功能是十分重要的,我們可以把一些在相對一段時(shí)間內(nèi)不發(fā)生改變的數(shù)據(jù)放在緩存中,這樣,就不必要每次去讀取數(shù)據(jù)庫,當(dāng)下次再需要這些數(shù)據(jù)時(shí),可以直接從緩存中取得,大大增強(qiáng)了效率。

  而在asp.net 1.1 中,已經(jīng)比較好地實(shí)現(xiàn)了數(shù)據(jù)的緩存功能,但有一個(gè)小問題,那就是如果數(shù)據(jù)庫中的數(shù)據(jù)發(fā)生了變化,緩存不能在指定的時(shí)間內(nèi)更新,而必須等到緩存失效。比如,在網(wǎng)頁中,如果你對商品的一些詳細(xì)信息,如價(jià)格等使用了頁面緩存,那么假如在后臺修改了這些信息,用戶不會馬上看到這些信息,而要延遲一些時(shí)間才看到。在某些應(yīng)用場合,如果你要做到對于數(shù)據(jù)庫的任何更新,都能馬上可以在緩存的變化生效的話,在asp.net 1.1中則是比較難實(shí)現(xiàn)的,而在asp.net 2.0中,則可以很方便地實(shí)現(xiàn)該功能。本文將以.net Framework 2.0 beta,visual web developer express beta ,來介紹該功能的實(shí)現(xiàn)。

  首先,在asp.net 2.0中,針對sql server 7/2000,以及即將發(fā)行的sql server 2005(Yukon),分別提供了新的緩存功能。這里著重介紹針對sql server 7/2000的緩存功能。這個(gè)新的數(shù)據(jù)緩存功能,叫做SqlCacheDependency,要實(shí)現(xiàn)該功能,需要采用如下步驟:

  1、在.net framework 2.0的安裝目錄下
(默認(rèn)是WINNT\Microsoft.NET\Framework\v2.0.40607),啟動一個(gè)叫aspnet_regsql.exe的命令行工具,比如:

aspnet_regsql -S localhost –U sa –P 123456 -d Pubs –ed

  上面的意思是,指定了本地的數(shù)據(jù)庫服務(wù)器localhost,并指定了登陸的用戶名和密碼,并用參數(shù)-d指定了要采用哪一個(gè)數(shù)據(jù)庫(這里是指定了pubs)數(shù)據(jù)庫,-ed參數(shù)表示是允許該數(shù)據(jù)庫使用sqlcachedependency功能。

  接著,我們需要指定對哪一個(gè)表使用數(shù)據(jù)sqlcachedependency功能,如:

aspnet_regsql -S localhost –U sa -P 123456 -ed -d pubs -et -t authors

  上面語句的意思是,指定對pubs數(shù)據(jù)庫中的authors表使用sqlcachedependency功能,-t參數(shù)后是表的名稱,-et是允許該表使用sqlcachedependency功能。其他的有關(guān)參數(shù)簡單介紹如下:

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

  Sqlcachedependency的的原理簡單來說,是采用aspnet_regsql這個(gè)專門工具,預(yù)先設(shè)定要監(jiān)視的數(shù)據(jù)庫和表,并在數(shù)據(jù)庫中增加一個(gè)專門的表,打開數(shù)據(jù)庫,會發(fā)現(xiàn)多了一個(gè)數(shù)據(jù)表aspnet_sqlcachetablesforchangenotification,如下圖:


  這個(gè)表有三個(gè)字段,“tableName”記錄要追蹤的數(shù)據(jù)表的名稱,“notificationCreated”記錄開始追蹤的時(shí)間,“changeId”是一個(gè)int類型的字段,每當(dāng)追蹤的數(shù)據(jù)表的數(shù)據(jù)發(fā)生變化時(shí),這個(gè)字段的值就加1。 此外還會在指定的數(shù)據(jù)庫中增加幾個(gè)存儲過程,用來讓ASP.NET引擎查詢追蹤的數(shù)據(jù)表的情況,并給要使用 Sqlcachedependency 的表加上若干觸發(fā)器,分別對應(yīng)到Insert、Update、Delete操作。ASP.NET引擎通過執(zhí)行它加上的存儲過程“AspNet_SqlCachePollingStoredProcedure”,這個(gè)存儲過程直接返回“AspNet_SqlCacheTablesForChangeNotification”表的內(nèi)容,讓ASP.NET引擎知道哪個(gè)表的數(shù)據(jù)發(fā)生的變化。

[page_break]

接下來,我們用visual web developer 2005 beta,來創(chuàng)建一個(gè)website,往其中增加一個(gè)label標(biāo)簽,以顯示當(dāng)前執(zhí)行的時(shí)間。并往其中增加一個(gè)gridview控件,用來顯示來自pubs數(shù)據(jù)庫的表authors,代碼如下:

<%@ Page Language="VB" AutoEventWireup="false" CompileWith="Default.aspx.vb" ClassName="Default_aspx" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form id="form1" runat="server">
 <asp:Label ID="Label1" Runat="server" Text="Label" Width="74px" Height="19px"></asp:Label> 
<br />
<asp:GridView ID="GridView1" Runat="server" DataSourceID="SqlDataSource1">
</asp:GridView>
<br />
<br />
<asp:SqlDataSource ID="SqlDataSource1" Runat="server" SelectCommand="SELECT * FROM authors"
ConnectionString="Initial Catalog=pubs;Data Source=localhost;user id=sa;password=123456">
</asp:SqlDataSource>
</form>
</body>
</html>


  在default.aspx.vb的代碼的page_load事件中,加入以下代碼

Private Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
Label1.Text = CType(System.DateTime.Now(), String)
End Sub


  接下來,我們開始配置web.config文件。我們采用的配置文件如下:

<?xml version="1.0"?>
<configuration>
<connectionStrings>
<add name="PubsConn" connectionString="Initial Catalog=pubs;Data Source=(local);user id=sa;password=123456"/>
</connectionStrings>
<system.web>
<caching>
<sqlCacheDependency enabled="true" pollTime="500">
<databases>
<add name="Pubs" connectionStringName="PubsConn"/>
</databases>
</sqlCacheDependency>
</caching>
</system.web>
</configuration>


  其中,要注意的是polltime參數(shù),polltime參數(shù)是毫秒,最小值為500,該參數(shù)的意義時(shí)設(shè)置系統(tǒng)多長時(shí)間去檢查一次cache中的數(shù)據(jù)是否需要更新。而<database>標(biāo)簽內(nèi)必須注明需要用到的數(shù)據(jù)庫連接字符串,必須和之前<connectionStrings>中定義的名稱相符合(如本例中,connectionstring的名稱是pubsconn。

  最后,我們在程序的首部,加入頁面緩存的定義語句如下:

<%@ outputcache duration="60" varybyparam="none" sqldependency="Pubs:authors" %>

  上面的語句,則定義了頁面輸出緩存為1分鐘,并且使用sqldependency,sqldependency的屬性中,以“名稱:表名”的形式定義,其中的名稱,就是剛才我們在web.config中定義的<databases>中的名稱,這里是pubs!癙ubs:authors”中的authors,則是要使用sqldependency的表名authors表。在這里要注意的是,雖然我們是用vb.net,但sqldependency屬性中的參數(shù)注定是大小寫敏感的,如“Pubs:authors”中的表名authors必須和用Aspnet_regsql在命令行下定義的表名authors一樣。

  運(yùn)行我們的程序,先不修改數(shù)據(jù)庫中的數(shù)據(jù)。如下圖:


  我們不斷刷新該應(yīng)用,會發(fā)現(xiàn)由于使用了緩存功能,上面的時(shí)間是不變的,F(xiàn)在我們打開sql server,修改其中的au_id為172-32-1176的作者名white,將其改為RED,之后再刷新程序,看到了么?由于使用了sqldependency的功能,馬上緩存中反映出新修改的數(shù)據(jù)了: