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

首頁 > 學院 > 開發設計 > 正文

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

2019-11-18 19:35:11
字體:
來源:轉載
供稿:網友

foxty [原作]

    近日一直在研究如何才能寫出高小的分頁算法,大概整理了一下,思路如下:
 
    首先數據庫里需要有一個自動編號字段(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.49028c.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…………依次類推,當需要訪問第 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
日本精品免费一区二区三区| 法国裸体一区二区| 国产精品激情av电影在线观看| 国产成人aa精品一区在线播放| 中日韩美女免费视频网站在线观看| 国产伦精品一区二区三区精品视频| 91chinesevideo永久地址| 欧美激情精品久久久久久黑人| 全色精品综合影院| 亚洲午夜精品视频| 欧美中文在线观看| 成人乱色短篇合集| 午夜精品久久久久久99热| 久久久亚洲国产| 成人a视频在线观看| 91久久久国产精品| 亚洲色图五月天| 在线观看日韩视频| 欧美疯狂xxxx大交乱88av| 亚洲欧美综合图区| 亚洲精品动漫100p| 国产中文欧美精品| 最近2019中文字幕在线高清| 日韩中文字幕精品视频| 91色视频在线导航| 亚洲人成77777在线观看网| 成人国产精品日本在线| 国产激情综合五月久久| 91tv亚洲精品香蕉国产一区7ujn| 91国自产精品中文字幕亚洲| 欧美精品videofree1080p| 亚洲欧美变态国产另类| 粉嫩av一区二区三区免费野| 欧美日韩美女在线观看| 国产精品私拍pans大尺度在线| 在线视频亚洲欧美| 午夜精品久久久久久久久久久久久| 欧美成人在线网站| 精品久久久久久久久久国产| 精品无人国产偷自产在线| 国产欧美日韩亚洲精品| 日韩亚洲精品视频| 亚洲xxxxx| 欧美影院在线播放| 国内精品久久久久影院 日本资源| 亚洲性无码av在线| 国产精品黄色影片导航在线观看| 亚洲国产精品成人va在线观看| 国产精品va在线| 国产精品网址在线| 久久99热精品| 亚洲aaa激情| 欧美精品18videos性欧美| 久久影视电视剧免费网站清宫辞电视| 欧美性开放视频| 少妇高潮久久久久久潘金莲| 国产日本欧美一区二区三区| 国产精品久久久久999| 亚洲第一偷拍网| 色午夜这里只有精品| 欧美区二区三区| 国产精品视频xxx| 最新国产成人av网站网址麻豆| 欧美另类69精品久久久久9999| 国产精品美女无圣光视频| 8x拔播拔播x8国产精品| 欧美精品成人在线| 久久久久久18| 精品一区精品二区| 亚洲欧美日韩中文视频| 国产视频精品久久久| 欧美日韩黄色大片| 一本一道久久a久久精品逆3p| 91精品久久久久久久久中文字幕| 7777kkkk成人观看| 丝袜亚洲另类欧美重口| 91精品中国老女人| 久久久久国色av免费观看性色| 97福利一区二区| 综合网中文字幕| 黑人巨大精品欧美一区二区一视频| 伊人精品在线观看| 青青a在线精品免费观看| 97在线观看免费高清| 色狠狠av一区二区三区香蕉蜜桃| 九九热精品视频在线播放| 亚洲人成伊人成综合网久久久| 亚洲男人7777| 久久久久久久999精品视频| 精品中文字幕在线2019| 久久久91精品国产一区不卡| 日韩电影视频免费| 中文字幕亚洲色图| 国产视频欧美视频| 国产精品欧美日韩| 久久夜色精品国产| 亚洲欧洲一区二区三区久久| 91高潮精品免费porn| 亚洲精品一区久久久久久| 91精品国产高清久久久久久91| 亚洲免费中文字幕| 国产精品一区二区3区| 亚洲精品欧美日韩| 欧美精品videos性欧美| 欧美激情伊人电影| 国内成人精品视频| 精品少妇v888av| 97热精品视频官网| 色无极影院亚洲| 精品国产成人av| 欧美日韩在线免费观看| 久久久精品视频在线观看| 欧美精品在线极品| 97视频在线看| 91免费国产网站| 午夜精品一区二区三区在线视频| 在线精品高清中文字幕| 亚洲国产一区二区三区在线观看| 亚洲欧美日韩高清| 国产综合久久久久| 国产一区二区日韩精品欧美精品| 日韩中文字幕不卡视频| 中文字幕日韩欧美在线视频| 富二代精品短视频| 欧美乱妇40p| 欧美又大又粗又长| 亚洲自拍小视频| 视频在线一区二区| 日本aⅴ大伊香蕉精品视频| 欧美大码xxxx| 亚洲激情在线观看| 夜夜嗨av色综合久久久综合网| 亚洲日韩中文字幕在线播放| 亚洲成人1234| 日韩在线免费av| 中文字幕在线国产精品| 亚洲欧美福利视频| 亚洲字幕一区二区| 欧美日韩午夜视频在线观看| 精品国产拍在线观看| 日韩在线观看电影| 久久综合伊人77777| 91精品啪在线观看麻豆免费| 91成人在线观看国产| 日韩欧美aaa| 久久久久免费精品国产| 欧美在线视频观看| 第一福利永久视频精品| 国产精品在线看| 日韩精品999| 成人久久18免费网站图片| 久久久久久久久久久国产| 国产欧美日韩精品丝袜高跟鞋| 国产精品一区专区欧美日韩| 欧美日韩亚洲网| 亚洲色无码播放| 欧美日韩爱爱视频| 欧美激情国内偷拍| 国内精品久久久久影院 日本资源| 日韩av观看网址| 日韩免费高清在线观看| 日韩一区二区三区xxxx| 亚洲国产古装精品网站| 亚洲影院色在线观看免费|