推薦:淺析asp無(wú)組件上傳并插入到數(shù)據(jù)庫(kù)里以下為引用的內(nèi)容: % Response.Buffer = True Server.ScriptTimeOut=9999999 On Error Resume Next %>
ASP從發(fā)布至今已經(jīng)7年了,使用ASP技術(shù)已經(jīng)相當(dāng)成熟,自從微軟推出了ASP.NET之后就逐漸停止了對(duì)ASP版本的更新。但是由于有很多人仍然習(xí)慣使用ASP來(lái)開發(fā)網(wǎng)站,所以,再次我將以一個(gè)簡(jiǎn)單的例子來(lái)說(shuō)明在ASP中如何使用Cache。
簡(jiǎn)單的說(shuō)使用Cache基本原理是,把經(jīng)常需要且獲得代價(jià)昂貴的數(shù)據(jù)在內(nèi)存中持續(xù)保存一定時(shí)間,以供這些數(shù)據(jù)可以被直接地全局地訪問。例如,有一些數(shù)據(jù)需要從數(shù)據(jù)庫(kù)多個(gè)表中查詢獲得,且?guī)缀趺總€(gè)頁(yè)面都要調(diào)用這些數(shù)據(jù)。
這種情況下的最佳實(shí)現(xiàn)就是將這部分?jǐn)?shù)據(jù)Cache起來(lái),在ASP中的簡(jiǎn)單實(shí)現(xiàn)就是將這些數(shù)據(jù)的最終表達(dá)形式(例如HTML流)封裝在string中然后存入ASP內(nèi)置對(duì)象Application中(本文主要討論的是動(dòng)態(tài)Cache,簡(jiǎn)單的ASP 應(yīng)用就省略)。這樣做的好處是,在整個(gè)網(wǎng)站中可以全局調(diào)用這段HTML,而且Application是存在內(nèi)存中,所以不用再去查詢數(shù)據(jù)庫(kù),從而加快了響應(yīng)時(shí)間并節(jié)省了服務(wù)器負(fù)荷。當(dāng)然這是以消耗內(nèi)存為代價(jià)的,是一個(gè)典型的以空間換時(shí)間的實(shí)例。
使用這種方法雖然有很多好處,但是再遇到頻繁變化的數(shù)據(jù)源(數(shù)據(jù)庫(kù))的時(shí)候,這種方法就可能不再適用,因?yàn)锳SP Application對(duì)象有一個(gè)缺點(diǎn),就是不能自動(dòng)隨數(shù)據(jù)源的變化而變化,或者控制刷新間隔。所以就需要開發(fā)人員編程來(lái)實(shí)現(xiàn)動(dòng)態(tài)Cache。當(dāng)然在程序設(shè)計(jì)的時(shí)候可以在所有進(jìn)行改變數(shù)據(jù)源(數(shù)據(jù)庫(kù))操作時(shí),就更新一次Appliction。從而使數(shù)據(jù)源(數(shù)據(jù)庫(kù))始終保持一致。這樣做在編程上要考慮的問題會(huì)比較多,容易遺漏細(xì)節(jié)。所以除了特定情況我不推薦使用這種方法。
我認(rèn)為在ASP中最好的辦法是用編程實(shí)現(xiàn)定時(shí)刷新Cache,也就是說(shuō)給Application中儲(chǔ)存的設(shè)一個(gè)過期時(shí)間。當(dāng)然,在ASP中Application對(duì)象沒有這樣一個(gè)ExpireTime屬性。這需要用程序?qū)崿F(xiàn)。
以下為引用的內(nèi)容: default.asp <%@Language=VBScript%> |
以下為引用的內(nèi)容: getcache.asp <% Const CACHE_DEFAULT_INTERVAL = 30 '每隔30秒刷新一次cache Dim HTMLStream Dim IsExpires IsExpires = CacheExpires Function CacheExpires Dim strLastupdate Dim result strLastupdate = Application("Lastupdate") If (strLastupdate = "") Or (CACHE_DEFAULT_INTERVAL < DateDiff("s", strLastupdate, Now)) Then result = true SetLastupdateTime Else result = false End If CacheExpires = result End Function
Sub SetLastupdateTime |
以下為引用的內(nèi)容: Sub updateHTMLStream dim d d = FetchHTMLStream Application.Lock Application("CACHE_HTMLStream") = d Application.UnLock End Sub
Function FetchHTMLStream |
以下為引用的內(nèi)容: conn.asp <!--METADATA NAME="Microsoft ActiveX Data Objects 2.5 Library" TYPE="TypeLib" UUID="{00000205-0000-0010-8000-00AA006D2EA4}"--> <% dim strConn strConn = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=Northwind" %> |
分享:如何用ASP顯示ACCESS數(shù)據(jù)庫(kù)的的GIF圖象寫入:1:把gif圖像文件讀入內(nèi)存(一個(gè)變量strTemp)。2:寫入數(shù)據(jù)庫(kù)。 以下為引用的內(nèi)容: Dim binTmp() As Byte Dim conn As ADODB.Conn
新聞熱點(diǎn)
疑難解答
圖片精選