«
在ASP中模拟.NET下的cache技术

时间:2008-5-31    作者:Deri    分类: 分享


   <p>  为了提高网站首页的性能,首页凡是需要调用数据库显示数据的地方都会先试图从缓存中调用数据,如果缓存中没有可用数据再打开数据库取出记录集,为了让页面显示数据和数据库在一定时间内同步,我们把缓存的过期时间设置成30秒。</p><p>  声明:缓存管理类出自于动网论坛7.0</p><p>  注意:最好不要在缓存里直接缓存带状态的对象和MTA模式的对象,比如说直接缓存记录集或者数据库链接对象等。</p><p>  <code><%<br />Sub ShowRsArr(rsArr)<br /> '用表格显示记录集getrows生成的数组的表结构<br /> '<br /> Response.Write "<table width=100% border=0 cellspacing=0 cellpadding=0>"<br /> If Not IsEmpty(rsArr) Then<br />  For y=0 To Ubound(rsArr,2)<br />   Response.Write"<tr>"<br />   for x=0 to Ubound(rsArr,1)<br />    Response.Write "<td>"&rsArr(x,y)&"</td>"<br />   next<br />   Response.Write"</tr>"<br />  next<br /> Else<br />  Response.Write "<tr>"<br />  Response.Write "<td colspan="&rs.fields.count-1&">No Records</td>"<br />  Response.Write "</tr>"<br /> End If<br /> Response.Write "</table>"<br />End Sub<br />Class Cls_Cache<br />Rem ==================使用说明=================================================================================<br />Rem = 本类模块是动网先锋原创,作者:迷城浪子。如采用本类模块,请不要去掉这个说明。这段注释不会影响执行的速度。=<br />Rem = 作用:缓存和缓存管理类 =<br />Rem = 公有变量:Reloadtime 过期时间(单位为分钟)缺省值为14400, =<br />Rem = MaxCount 缓存对象的最大值,超过则自动删除使用次数少的对象。缺省值为300 =<br />Rem = CacheName 缓存组的总名称,缺省值为"Dvbbs",如果一个站点中有超过一个缓存组,则需要外部改变这个值。 =<br />Rem = 属性:Name 定义缓存对象名称,只写属性。 =<br />Rem = 属性:value 读取和写入缓存数据。 =<br />Rem = 函数:ObjIsEmpty()判断当前缓存是否过期。 =<br />Rem = 方法:DelCahe(MyCaheName)手工删除一个缓存对象,参数是缓存对象的名称。 =<br />Rem ===========================================================================================================<br />Public Reloadtime,MaxCount,CacheName<br /> Private LocalCacheName,CacheData,DelCount<br /> Private Sub Class_Initialize()<br />  Reloadtime=14400<br />  CacheName="Dvbbs"<br /> End Sub<br />Private Sub SetCache(SetName,NewValue)<br /> Application.Lock<br /> Application(SetName) = NewValue<br /> Application.unLock<br />End Sub<br />Private Sub makeEmpty(SetName)<br /> Application.Lock<br /> Application(SetName) = Empty<br /> Application.unLock<br />End Sub<br />Public Property Let Name(ByVal vNewValue)<br /> LocalCacheName=LCase(vNewValue)<br />End Property<br />Public Property Let Value(ByVal vNewValue)<br /> If LocalCacheName<>"" Then<br />  CacheData=Application(CacheName&"_"&LocalCacheName)<br />  If IsArray(CacheData) Then<br />   CacheData(0)=vNewValue<br />   CacheData(1)=Now()<br />  Else<br />   ReDim CacheData(2)<br />   CacheData(0)=vNewValue<br />   CacheData(1)=Now()<br />  End If<br />  SetCache CacheName&"_"&LocalCacheName,CacheData<br /> Else<br />  Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName."<br /> End If<br />End Property<br />Public Property Get Value()<br /> If LocalCacheName<>"" Then<br />  CacheData=Application(CacheName&"_"&LocalCacheName)<br />  If IsArray(CacheData) Then<br />   Value=CacheData(0)<br />  Else<br />   Err.Raise vbObjectError + 1, "DvbbsCacheServer", " The CacheData Is Empty."<br />  End If<br /> Else<br />  Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName."<br /> End If<br />End Property<br />Public Function ObjIsEmpty()<br /> ObjIsEmpty=True<br /> CacheData=Application(CacheName&"_"&LocalCacheName)<br /> If Not IsArray(CacheData) Then Exit Function<br /> If Not IsDate(CacheData(1)) Then Exit Function<br /> If DateDiff("s",CDate(CacheData(1)),Now()) < 60*Reloadtime Then<br />  ObjIsEmpty=False<br /> End If<br />End Function<br />Public Sub DelCahe(MyCaheName)<br /> makeEmpty(CacheName&"_"&MyCaheName)<br />End Sub<br />End Class<br />Dim strconn,rs<br />strconn="Driver={sql server};server=localhost;database=northwind;uid=sa;pwd=sa;"<br />Public Function GetEmployees()<br /> Dim SQL,Rs,Cache<br /> Set Cache=New Cls_Cache<br /> Cache.Reloadtime=0.5<br /> Cache.CacheName="wawa"<br /> Cache.Name="Employees"<br /> If Cache.ObjIsEmpty() Then<br />  Set rs=Server.CreateObject("ADODB.Recordset")<br />  SQL = "select EmployeeID, LastName, FirstName from employees order by employeeid desc"<br />  Rs.Open SQL,strconn,1,1<br />  Cache.value = Rs.GetRows(5)<br />  Rs.Close:Set Rs=Nothing<br /> End If<br /> GetEmployees=Cache.Value<br /> Set Cache=Nothing<br />End Function<br />ShowRsArr(GetEmpLoyees)<br />%><br /><script><br />function TimeOut(a){<br /> var c=a-1;<br /> if(c==0) {<br />  window.location.href=window.location;<br /> }else{<br />  document.all.abc.innerHTML="离缓存结束还有:"+c+"秒";<br />  window.setTimeout('TimeOut('+c+')',1000);<br /> }<br />}<br /></script><br /><body onload="TimeOut('30')"><br /><div id="abc"></div></code></p>