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

首頁 > 編程 > ASP > 正文

在Asp中如何快速優化分頁的技巧

2024-05-04 11:07:26
字體:
來源:轉載
供稿:網友

近日一直在研究如何才能寫出高小的分頁算法,大概整理了一下,思路如下:  
 
    首先數據庫里需要有一個自動編號字段(ID)。然后第一次訪問的時候,取出所有記錄,定制好每頁的記錄數PageSize,計算出頁數,然后根據頁數建立一個一維數組PageId(PageCount),PageId(0)保存記錄初試條件,然后對應每個元素保存每頁對應的ID邊界碼  
 
(  
 
  1,ID邊界碼:如果數據庫記錄ID記錄序列如下  1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16  
 
  假設需要按照ID 順序排序的話 ,PageSize = 5, Pagecount = 4 ,PageId(4)  
 
   數組PageId的值分別為PageId(0) = 1, PageId(1) = 5 ,PageId(2) = 10,PageId(3) = 15 ,PageId(4) = 16  
 
   當訪問第 i 頁的時候就直接找 [PageId(i-1) , PageId(i) ) 之間的記錄,這樣可以保證每次取的記錄都只是PageSize 條記錄。   
 
  假設需要按照ID倒序排列的話,  
 
   數組PageId的值分別為PageId(0) = 16 , PageId(1) = 12 , PageId(2) = 7 ,PageId(3) = 2, PageId(4) = 1, 當訪問第 i 頁的時候就直接查找ID屬于[ PageId(i-1) , PageId(i) )    

)  
 
 將數組PageId()保存在Application()中,以便訪問,這樣,只是第一次訪問分頁程序的時候便初始化Application()。代碼部分如下:(下面稱為新程序)  

<%  
 
 Time1 = Timer()  
 
 Dim Conn  
 
 Set Conn = Server.CreateObject("Adodb.Connection")  
 
 Conn.open "Driver={MicroSoft Access Driver (*.mdb)};Dbq="&Server.MapPath("db.mdb")  
 
 www.knowsky.com  
 
 Dim Page,PageCounts,PageId,PageList  
 
 Dim Rs,Sql  
 
 Dim IsInit,i  

 IsInit   = False                                         '標志為,用來判斷Application("PageId")是否初始化  
 
 PageList = 20                                            '設置每頁顯示20條數據  
 
 Set Rs    = Server.CreateObject("Adodb.Recordset")  
 
 Page     = Request.QueryString("Page")                         '注意頁碼需要檢查類型   

 If IsEmpty(Application("PageId")) Then               '如果Application("PageId")還未初始化,則先進行初始化  
 
  Response.Write("Init app!<br>")  
 
  Sql      = "Select * From test Order By Id Desc"  '假定這里是按照ID倒序排列  
 
  Rs.open Sql,Conn,1,1  '得到記錄集對象  

  If Not (Rs.Eof  or Rs.Bof) Then   
 
   Rs.PageSize = PageList                        '設置每頁記錄數  
 
   PageCounts  = Rs.PageCount  
 
   ReDim PageId(PageCounts)                      '重新定義數組PageId  
 
   For i = 0 To PageCounts                       '開始給數組 PageId() 賦值      
 
    If Rs.eof Then Exit For  
 
    PageId(i) = Rs("ID")  
 
    Rs.Move (PageList)  
 
   Next  
 
   Rs.MoveLast  
 
   PageId(PageCounts) = Rs("ID")  
 
   Application.Lock()  
 
   Application("PageId") = PageId  
 
   Application.UnLock()    
 
  End If  
 
  Rs.Close  
 
 End If  
 
 IdStart = Clng(Application("PageId")(Page-1))  
 
 IdEnd   = Clng(Application("PageId")(Page))  
 
 Sql = "Select * from test where id<="&IdStart&" and id>"&IdEnd&" "  
 
 Rs.open Sql,Conn,1,1  
 
 While Not Rs.eof  
 
  Response.Write(rs(0)&"--"&rs(1))   
 
  Rs.MoveNext  
 
 Wend  
 
 Rs.Close    
 
 Set Rs = Nothing 
 
 Conn.Close  
 
 Set Conn = Nothing 

 For i = 1 To Ubound(Application("PageId"))  
 
  Response.Write("<a href='Test1.asp?Page="&i&"'>"&i&"</a> ")  
 
 Next  
 
 Time2 = Timer()  

 Response.Write("<br>"&(Time2-Time1)*1000)   
 
 'Application.Contents.Remove("PageId")  
 
%>   

傳統分頁代碼如下:(下面稱為舊程序)  
 
<%  
 
 Time1 = Timer()  
 
 Dim Conn  
 
 Set Conn = Server.CreateObject("Adodb.Connection")  
 
 Conn.open "Driver={MicroSoft Access Driver (*.mdb)};Dbq="&Server.MapPath("db.mdb")  
 
 Dim Page,PageCounts,PageList  
 
 Dim Rs,Sql  

 PageList = 20 
 
 Page     = Request.QueryString( "Page" )  
 
 Set Rs   = Server.CreateObject("Adodb.Recordset")  
 
 Sql      = "Select * from test order by id desc" 
 
 Rs.Open Sql,Conn,1,1  
 
 If Page = "" Then Page = 1 
 
 If Not( Rs.eof Or Rs.Bof ) Then  
 
  Rs.PageSize     = PageList 
 
  PageCounts      = Rs.PageCount  
 
  Rs.AbsolutePage = Page    
 
 End If  
 
 For i = 1 to PageList  
 
  If Rs.eof Then Exit For  
 
  Response.Write(Rs(0)&"-----"&Rs(1)&"<br>")  
 
  Rs.MoveNext  
 
 next  
 
 For i = 1 To PageCounts  
 
  Response.Write("<a href='Test.asp?Page="&i&"'>"&i&"</a> ")  
 
 Next  
 
 Time2 = Timer()  
 
 Response.Write("<br>"&(Time2-Time1)*1000)   
 
%> 
 
    其實,總體的思想就是,建立一個Application("PageId")全局數組,每個元素都保存頁面所區記錄的ID區間,比如,Application("PageId")(0) 保存第一個元素的ID,然后Application("PageId")(1)保存下一頁的第一個ID&hellip;………依次類推,當需要訪問第 i 頁的時候,就直接查找ID在 [ Application("PageId")(i-1)  , Application("i") ) 里面的記錄集,這樣,每次只用查找需要的記錄數,而不需要每次都把所有記錄都查找一遍,但是,這個方法是在第一次訪問的時候,即需要創建數組Application("PageId")的時候比較慢一點,當第N次訪問的時候 (N>1)速度就快將近10倍,我采用上面2個程序測試:  
 
  1,數據庫記錄有32000條記錄,舊程序訪問一頁需要500毫秒左右,新程序只是第一次訪問的時候達到這個時間,然后每次都只需要55毫秒左右。  
 
  2,將數據增加到64000條記錄,舊程序訪問一頁需要1000毫秒左右,新程序也是第一次訪問的時候達到這個似乎件, 后面每次仍然還是保持在55毫秒左右。  
 
  3,將數據增加到128000條記錄,舊程序訪問一頁需要1900毫秒左右,新程序第一次訪問需要2300毫秒左右,然后每次訪問只需要70毫秒左右。  
 
  這里需要注意的是數據庫每改動一次,Application("PageId") 就需要重新賦值!  
 
    研究心得:(首先謝謝葉子(DVBBS)的心得)盡量不要用自帶的分頁程序,Rs.RecordCount 很耗資源。依次,估計Rs.PageCount ……也耗資源,而且用Rs.GetRows()效果也很明顯提高。  
 
    經過比較,葉子的算法在記錄比較靠前的時候速度以及效率是比較高的。但是不太穩定,有時(很少)會從30毫秒左右跳到1-200毫秒。到了后面效率就明顯下降到50-80毫秒,越后效率越低。新算法第一次效率比較低下,大約在500毫秒左右,但是比較穩定,后面一般哦度是50毫秒左右,而且隨著庫的記錄數變化,這個速度依然如此。不會有什么變化。下次就把葉子和我的算法結合起來試試,不過葉子的算法確實是很不錯D,具備通用性。我這個只能拿來聊聊了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美整片在线观看| 国产亚洲欧美日韩一区二区| 日韩电影免费观看中文字幕| 欧美成人免费一级人片100| 日本久久久久久久久| 欧美成人免费va影院高清| 欧美性猛交99久久久久99按摩| 国产做受高潮69| 日韩精品视频在线免费观看| 国产综合在线观看视频| 日韩中文字幕在线免费观看| 欧美一级免费视频| 欧美激情网站在线观看| 插插插亚洲综合网| 国产99久久精品一区二区永久免费| 亚洲无线码在线一区观看| 午夜精品一区二区三区在线视| 国产美女久久精品香蕉69| 在线日韩欧美视频| 亚洲乱亚洲乱妇无码| 国产日产亚洲精品| 久久久久久av| 亚州av一区二区| 精品国产精品三级精品av网址| 国产99久久精品一区二区永久免费| 97视频在线观看成人| 午夜精品99久久免费| 日韩欧美国产激情| 日韩黄色av网站| 亚洲free嫩bbb| 日本sm极度另类视频| 久久精品免费播放| 精品国产精品三级精品av网址| 亚洲第一福利视频| 国产亚洲精品美女久久久| 揄拍成人国产精品视频| 国内揄拍国内精品少妇国语| 午夜剧场成人观在线视频免费观看| 精品国产一区二区三区久久久| 亚洲香蕉av在线一区二区三区| 97视频在线观看亚洲| 亚洲欧洲日产国码av系列天堂| 亚洲欧洲黄色网| 国产欧美一区二区三区视频| 欧美电影在线观看网站| 欧美激情精品久久久久| 国产精品久久久av久久久| 亚洲女在线观看| 中文综合在线观看| 91精品国产综合久久男男| 国内精品小视频在线观看| 97色在线视频| 国产亚洲精品美女久久久久| 自拍偷拍亚洲欧美| 在线观看中文字幕亚洲| 午夜精品一区二区三区在线| 亚洲欧美日韩图片| 中文字幕在线国产精品| 国产精品扒开腿做爽爽爽的视频| 激情懂色av一区av二区av| 精品五月天久久| 成人午夜在线影院| 亚洲人在线视频| 亚洲xxxx视频| 欧美乱大交做爰xxxⅹ性3| 国产视频亚洲精品| 久久97久久97精品免视看| 中文字幕精品www乱入免费视频| 最近2019免费中文字幕视频三| 在线视频精品一| 高跟丝袜一区二区三区| 中文字幕无线精品亚洲乱码一区| 国产亚洲日本欧美韩国| 日韩av在线看| 国产精品69精品一区二区三区| 亚洲奶大毛多的老太婆| 国产免费久久av| 欧美午夜精品久久久久久久| 一二美女精品欧洲| 亚洲第一男人av| 国产精品美女在线| 波霸ol色综合久久| 国产成人av在线播放| 欧美久久久精品| 欧美福利小视频| 亚洲国产精品久久久| 欧美国产一区二区三区| 久久精品视频va| 欧美大片在线免费观看| 日本高清+成人网在线观看| 91精品视频在线播放| 中文字幕欧美日韩va免费视频| 日韩激情在线视频| 亚洲日韩中文字幕| 日韩欧美亚洲综合| 久久久久久尹人网香蕉| 97人人爽人人喊人人模波多| 亚洲欧美一区二区三区久久| 激情成人中文字幕| 精品国产视频在线| 91国产精品视频在线| 日韩欧美黄色动漫| 欧美激情一区二区三区在线视频观看| 国产精品久久久久久久久久久新郎| 欧美刺激性大交免费视频| 亚洲最大av网站| 亚洲精品久久久一区二区三区| 欧美色另类天堂2015| 最近2019中文字幕一页二页| 色综合老司机第九色激情| 日本一区二区三区四区视频| 性色av一区二区咪爱| 色偷偷噜噜噜亚洲男人| 日韩精品免费在线视频| 热久久这里只有| 国产精品精品久久久| 精品一区二区三区电影| 亚洲第一视频在线观看| 久久国产视频网站| 九九精品在线观看| 国产欧美日韩91| 日韩欧美在线国产| 久久久久久久国产精品视频| 亚洲国产精品福利| 久久久免费高清电视剧观看| 性欧美亚洲xxxx乳在线观看| 成人国产精品一区二区| 中国china体内裑精亚洲片| 国产精品流白浆视频| 亚洲一区二区免费| 成人免费淫片aa视频免费| 久久久久中文字幕| 亚洲欧洲在线播放| 国产成人+综合亚洲+天堂| 精品成人久久av| 69国产精品成人在线播放| 欧美日韩国产精品一区二区不卡中文| 影音先锋欧美精品| 国产亚洲精品久久久久久| 国产亚洲精品久久久优势| 欧美福利在线观看| 国产亚洲欧洲在线| 国产精品白丝jk喷水视频一区| 91免费视频网站| 日韩欧美国产骚| 欧美国产日韩一区二区三区| 日韩av在线影视| 久99久在线视频| 亚洲国产日韩欧美在线动漫| 久久久久久久久久久91| 日韩精品在线电影| 日韩中文字幕网站| 2019精品视频| 欧美成年人网站| 久久精品国产v日韩v亚洲| 永久免费毛片在线播放不卡| 精品一区二区三区四区| 视频一区视频二区国产精品| 亚洲欧美激情另类校园| 国产一区二区三区18| 日韩在线资源网| 美女精品久久久| 久久免费高清视频| 成人午夜小视频|