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

首頁 > 編程 > ASP > 正文

最快的Web數據庫分頁方法

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

現在web數據庫的應用越來越多了,但是在web的頁面中實現數據庫記錄的分頁是一件很復雜的技術,那么你知道如何實現web數據庫分頁方法嗎?現在我們就去看看最快的Web數據庫分頁方法。

一:構思。?
  在設計Web數據庫時,如果我們要編歷每一條紀錄,那么只有采取分頁模式才可以使Web數據庫盡快,盡好的呈現給終端用戶,也不會因為8秒原則而使用戶失去瀏覽該頁的興趣。但是即使采取分頁的辦法,當出現多紀錄的數據庫時,也難免會使我們的用戶感到翻頁時速度太慢。就如同我的上篇文章說的那樣,幾乎上一片文章的三種分頁方法都有一些缺陷。那么,我們如何做到能讓數據庫每次就取我們需要的紀錄,這個很好實現,有游標返回多個紀錄集就可以實現,但是如果讓數據庫的一端不會因為要剛好檢索一頁的紀錄而大耗資源就很難了。最后,經過我的不斷改寫程序與測試,終于編寫出了我認為理論上最快的Web數據庫分頁方法。?

二:具體實現的存儲過程。?
  我們結合一個BBS問題來談談這種方法。如何讓一個BBS每次每頁只現實需要的一頁紀錄呢?而我們需要提供給數據庫有那些參數呢?可能會有以下參數。?
  第一:就是我們需要的當前的頁數。?
  第二:當前定義的每一頁的紀錄集數目。這樣你就可以根據需要在頁面程序中修改每一頁的紀錄數。當然,如果你不考慮程序的可擴展性,你也可以在數據庫里直接規定每一頁有N條紀錄即可。?
  第三:一個輸出參數:就是從數據庫里得出當前表中總紀錄數目的多少。(注意,他不是一個頁的紀錄數目)他相當于ADO分頁法中的Recordcount。如果你不需要總紀錄數目可以不用返回他。?
  我們來看具體存儲過程的代碼。。。?

CREATE?PROCEDURE?dbo.PRO_pageview?
(?

@tint_tableid?tinyint=1,   --這個是BBS的當前版面Id,你可以不用管他。。?
@int_pagenow?int=0,      ?
@int_pagesize?int=0,?
@int_recordcount?int=0?output ?--就是得出BBS某個版面的總貼數。。?

)?

AS?
set?nocount?on?

declare?@int_allid?int    ?
declare?@int_beginid?int,@int_endid?int ?
declare?@int_pagebegin?int,?@int_pageend?int?
  ?
select?@int_allid=count(*)?from?tab_discuss?where?tint_level=0?and?tint_tableid=@tint_tableid?
  select?@int_recordcount=@int_allid    ?--得出該版面的總貼數?
      ?
  declare?cro_fastread?cursor?scroll?
  for  select?int_id?from?tab_discuss?where?tint_level=0?and?tint_tableid=@tint_tableid?order?by?int_id?desc --這里定義游標操作,但是不用臨時紀錄集,而且游標也不需要全部遍歷所有紀錄集。?
  ?
  open?cro_fastread --打開游標?
  select?@int_beginid=(@int_pagenow-1)*@int_pagesize+1 得出該頁的第一個紀錄Id?
  select?@int_endid?=?@int_beginid+@int_pagesize-1   得出該頁的最后一個紀錄的Id?
  ?
  fetch?absolute @int_beginid?from?cro_fastread?into?@int_pagebegin?將他的Id傳給一個變量該頁開始的Id?
  if?@int_endid>@int_allid    --這里要注意,如果某一頁不足固定頁數的紀錄時。如只有一頁紀錄,而且紀錄少于我們定義的數目?;蛘呤亲詈笠豁摃r。。。?
    fetch?last?from?cro_fastread?into?@int_pageend ?--直接將游標絕對定位到最后一條紀錄,得出他的id號來。。。?
  else?
    fetch?absolute?@int_endid?from?cro_fastread?into?@int_pageend?
        ?
  select?int_id,tint_level,tint_children,var_face,var_subject,datalength(txt_content)?as?int_len,sint_hits,var_url,var_image,var_user,dat_time,tint_tableid,bit_kernul?from?tab_discuss?where?tint_tableid=@tint_tableid and?int_rootid?between?@int_pageend?and?@int_pagebegin?order?by?int_rootid?desc,num_order?desc  ?--我們就可以利用該頁的第一個id和最后一個id得出中間的id來。。。。(注意。我們這個BBS的數性結構用了一種很巧妙的算法,就是用一個orderNum浮點數即可完成排序。。。)?

--開始清場。。。?
  close?cro_fastread     ?
  deallocate?cro_fastread?
  ?
  return?


我們再看看Asp頁面里的程序操作。。。?

pagenow=cint(request("pagenow"))?--當前的頁面。?

if?pagenow<=0?then?pagenow=1?
pagesize=10?

set?cmd=server.CreateObject("adodb.command")?
cmd.ActiveConnection=strconn?
cmd.CommandType=4?
cmd.CommandText="pro_pageview"?

cmd.Parameters.Append?cmd.CreateParameter("tint_tableid",adInteger,adParamInput,,tint_tableid)?
cmd.Parameters.Append?cmd.CreateParameter("int_pagenow",adInteger,adParamInput,,pagenow)?
cmd.Parameters.Append?cmd.CreateParameter("int_pagesize",adInteger,adParamInput,,pagesize)?
cmd.Parameters.Append?cmd.CreateParameter("int_recordcount",adInteger,adParamOutput)?

set?rs=cmd.Execute?
if?rs.eof?then?
  Response.Write?"目前已超過了紀錄個數或紀錄集為空!"?
  Response.End?
end?if?

dim?arrRs?
arrRs=rs.getrows  ?'可以利用getRows將紀錄集迅速保存到一個二維的數組中來提高速度。?

recordcount=cmd.Parameters("int_recordcount")?
'注意,當紀錄不足以剛好整除單位頁紀錄時,我們也要將其定義為一頁,如紀錄數目為2頁多一個紀錄,此時我們的頁數也要為3頁紀錄。?
if?(recordcount?mod?pagesize)=0?then?
  pagecount=recordcount/pagesize?
else?
  pagecount=recordcount/pagesize+1?
end?if?


<--分頁開始?-->?
<!--?#include?file="include/tablepage.asp"?-->固定的分頁函數,其實無非是pagenow+1或pagenow-1,pagenow,pagecount?
<!--分頁結束-->?


<div?align="left"?class="pblank"?>?
<%?
'---------顯示樹性結構!-------------?
level=0?
Response.Write?"<ul>"?
for?i=0?to?ubound(arrRs,2)?
  if?arrRs(1,i)>level?then?
    Response.Write?"<ul>"?
  end?if?
  if?arrRs(1,i)<level?then?
    for?j=arrRs(1,i)?to?level-1?
        Response.Write?"</ul>"?
    next?
  end?if?
  int_size=arrRs(5,i)?
  if?int_size=0?then?
    str_size="?<無內容>"?
  else?
    str_size=""?
  end?if?
  Response.Write?"<li><img?src=face/"&arrRs(3,i)&"><a?href=showTitle.asp?int_id="&arrRs(0,i)&"&tint_tableid="&tint_tableid&"?class=ptitle?target=BoardAnnounce>"&server.HTMLEncode(arrRs(4,i))&"</a>?"&str_size?
  if?arrRs(7,i)<>""?then?Response.Write?"?<連接>?"?
  if?arrRs(8,i)<>""?then?Response.Write?"?<圖像>?"?
  Response.Write?"  ?-【"&arrRs(9,i)&"】?<font?color=444444>"&arrRs(10,i)&"</font> [<font?color=920092>ID:"&arrRs(0,i)&" 點擊:"&arrRs(6,i)&"次</font>] <font?color=444444>("&int_size&"字節)</font> <font?color=ff0000>("&arrRs(2,i)&")</font></li>"?
  ?
  ?
  level=arrRs(1,i)?
  ?
next?

Response.Write?"</ul>"?
'---------顯示樹性結構完畢!-------------?

%>?
</div>?
<div?align="left">?
<!--分頁開始?-->?
<!--?#include?file="include/tablepage.asp"?-->?
<!--分頁結束-->?
</div>?
<!--?清場與除錯?-->?
<%?
rs.close?
set?rs=nothing?
set?cmd=nothing?
if?err.number<>0?then?Response.Redirect?"bug.asp"?
%>?

三:特點?
  我們來看看他和傳統的三種方法的區別與特點?
  第一:每次只傳回一頁紀錄,而且只形成一個紀錄集,而且客戶端可以采用速度最快的火線游標來完成頁面輸出。而不必像傳統的游標法用rs.nextrecordset紀錄來輸出紀錄。?
  第二:數據庫沒有用到臨時表,這樣比轉儲紀錄集的速度大大提高。?
  第三:采用一個滾動游標,而且游標只經過二個操作就完成定位。速度也大大提高。?
  ?
  當我采用了這種分頁方法時,已經可以明顯的感覺出分頁速度的提高了。當然,在處理樹型結構,數據庫運算時,我采用了許多方法盡可能的提高速度,如:采用二分區間法來編歷樹型結構,全部采用存儲過程來實現一切sql操作,采用觸發器和數據庫游標來完成數據庫算法,這樣就盡量避免過多的網絡傳輸。任何操作只和數據庫進行一次參數傳遞就可以完成。?
  上文中為大家詳細介紹了最快的Web數據庫分頁方法,通過上面結果表明,利用存儲過程分頁可以有效提高web數據數據訪問的效率。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
www.日本久久久久com.| 日韩视频亚洲视频| 亚洲天堂久久av| 日韩av在线免费播放| 欧美激情日韩图片| 亚洲国产精品国自产拍av秋霞| 97av在线视频| 欧美成人自拍视频| 日韩在线一区二区三区免费视频| 亚洲成av人影院在线观看| 中文字幕欧美精品在线| 国产69精品99久久久久久宅男| 午夜精品在线观看| 亚洲片国产一区一级在线观看| 97久久伊人激情网| 精品在线小视频| 国内精品小视频在线观看| 成人黄色av网站| 久久久精品国产亚洲| 国产午夜精品一区理论片飘花| 久久久久久高潮国产精品视| 国产精品久久久久999| 中文字幕亚洲欧美日韩2019| 日韩美女写真福利在线观看| 欧美另类精品xxxx孕妇| 性欧美亚洲xxxx乳在线观看| 日本欧美爱爱爱| 久久精品国产一区二区电影| 中文字幕日韩av综合精品| 日本久久久久久久| 欧美多人爱爱视频网站| 国产一区二区美女视频| 亚洲欧洲激情在线| 精品国产依人香蕉在线精品| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲欧美中文字幕| 色综合久久久888| 欧美激情一级二级| 一区二区三区黄色| 亚洲黄色av网站| 有码中文亚洲精品| 亲爱的老师9免费观看全集电视剧| 欧美激情一区二区三区高清视频| 91九色在线视频| 亚洲三级黄色在线观看| 人九九综合九九宗合| 日韩美女视频免费在线观看| 欧美午夜激情视频| 久久99久久久久久久噜噜| 亚洲国产精品免费| 青青a在线精品免费观看| 秋霞av国产精品一区| 亚洲国产日韩欧美在线动漫| 欧亚精品在线观看| 主播福利视频一区| 欧美在线视频观看| 国产a∨精品一区二区三区不卡| 97在线看福利| 亚洲欧美国产高清va在线播| 日韩性xxxx爱| 亚洲第一精品夜夜躁人人躁| 久久久久99精品久久久久| 国产不卡av在线免费观看| 亚洲美女黄色片| 国产精品99久久久久久人| 97欧美精品一区二区三区| 精品爽片免费看久久| 久久久久免费精品国产| 国产精品99久久久久久久久久久久| 亚洲电影免费观看高清完整版在线观看| 国产成人鲁鲁免费视频a| 欧洲亚洲女同hd| 久久久久久中文字幕| 一区二区三区视频观看| 欧美大片va欧美在线播放| 国产人妖伪娘一区91| 97视频免费在线看| 精品性高朝久久久久久久| 国产乱人伦真实精品视频| 2019国产精品自在线拍国产不卡| 91国内在线视频| 亚洲一区二区三区在线视频| 国产精品色视频| 久久久999成人| 色哟哟亚洲精品一区二区| 国产精品91免费在线| 日韩精品久久久久久福利| 精品久久久久久久久久国产| 精品国产一区二区三区四区在线观看| 91精品国产高清久久久久久| 日本精品久久中文字幕佐佐木| 国产精品6699| 国产精品一区二区3区| 亚洲欧美日韩一区二区在线| 久久精品成人欧美大片| 91午夜理伦私人影院| 欧美国产日韩免费| 97视频国产在线| 久久99热这里只有精品国产| 亚洲成人精品av| 欧美日韩一二三四五区| 91wwwcom在线观看| 久久久久久久久久国产精品| 国产91精品不卡视频| 亚洲免费av网址| 国产精品爽爽爽爽爽爽在线观看| 国产精品黄视频| 欧美性理论片在线观看片免费| 97在线看福利| 久久久999国产精品| 欧美日韩精品中文字幕| 欧美一区二区视频97| 色综合久久精品亚洲国产| 欧美大片免费观看在线观看网站推荐| 人妖精品videosex性欧美| 久久久久久久久久av| 九九精品在线观看| 亚洲精品aⅴ中文字幕乱码| 91精品久久久久| 一区二区三区国产视频| 欧美电影免费观看大全| 欧美在线视频免费播放| 日本高清视频一区| 北条麻妃久久精品| 最新91在线视频| 久热精品视频在线观看一区| 在线亚洲欧美视频| 国产亚洲精品久久久久动| 亚洲美女在线观看| 久久国产精品99国产精| 亚洲精品大尺度| www国产精品视频| 狠狠躁夜夜躁人人爽天天天天97| 国产偷亚洲偷欧美偷精品| 亚洲免费av网址| 中文字幕v亚洲ⅴv天堂| 最近日韩中文字幕中文| 午夜精品视频在线| 国产精品网站视频| 在线成人中文字幕| 久久精品国产电影| 成人免费xxxxx在线观看| 国产日韩av在线| 久久91亚洲人成电影网站| 最近中文字幕mv在线一区二区三区四区| 国产成人在线播放| 亚洲在线第一页| 国产精品九九久久久久久久| 一区二区欧美在线| 国产精品女人久久久久久| 亚洲风情亚aⅴ在线发布| 精品国产一区二区三区在线观看| 91九色国产在线| 亚洲第一色在线| 国产精品免费在线免费| 2025国产精品视频| 97视频在线观看播放| 久久中国妇女中文字幕| 91亚洲精品久久久| 国产999精品| 久久久久久久久久久免费精品| 在线观看91久久久久久| 精品国产区一区二区三区在线观看| 欧美成人激情视频免费观看|