校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 一種理論上最快的Web數據庫分頁方法

一種理論上最快的Web數據庫分頁方法

熱門標簽:長春公司外呼系統中心 沈陽電話機器人公司 虛擬電話外呼系統 沈陽三五防封電銷卡 成都ai外呼系統線路 鄢陵學校如何做地圖標注 云南便宜外呼系統平臺 廣東語音外呼系統公司 鄭州智能外呼電銷機器人廠家
出了一種理論上最佳的分頁方法,本篇我們就來詳細說說這種最佳的分頁方法。 

一:構思。 
  在設計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    --這里要注意,如果某一頁不足固定頁數的紀錄時。如只有一頁紀錄,而且紀錄少于我們定義的數目。或者是最后一頁時。。。 
    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操作,采用觸發器和數據庫游標來完成數據庫算法,這樣就盡量避免過多的網絡傳輸。任何操作只和數據庫進行一次參數傳遞就可以完成。 
  感興趣的朋友可以到我的論壇來看看:http://tec.xj169.net/bbs

標簽:朝陽 湖北 馬鞍山 孝感 遼陽 平頂山 防城港 四平

巨人網絡通訊聲明:本文標題《一種理論上最快的Web數據庫分頁方法》,本文關鍵詞  一種,理論上,最,快的,Web,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《一種理論上最快的Web數據庫分頁方法》相關的同類信息!
  • 本頁收集關于一種理論上最快的Web數據庫分頁方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产精品白丝在线| 国产精品国产自产拍高清av王其| 亚洲一区欧美一区| 水蜜桃久久夜色精品一区的特点| 8v天堂国产在线一区二区| 国产精品久久久久久久岛一牛影视| 久久影院视频免费| 午夜视频一区二区三区| 在线一区二区三区四区| 亚洲欧美另类久久久精品2019| 国产精品国产三级国产有无不卡| 欧美一区二区二区| 美日韩一区二区| 日韩一区二区三区电影| 黄色日韩网站视频| 久久久国产精品麻豆| 91毛片在线观看| 午夜视频在线观看一区| 久久免费视频色| 日本电影欧美片| 亚洲一区在线观看免费观看电影高清| 视频一区视频二区中文| 欧美日韩中文字幕一区| 久久综合99re88久久爱| k8久久久一区二区三区| 国产精品久久久久永久免费观看 | 亚洲少妇屁股交4| av不卡免费在线观看| 午夜精品久久久久久久99樱桃| 精久久久久久久久久久| 国产精品久久毛片| 欧美综合天天夜夜久久| 成人免费毛片嘿嘿连载视频| 一区二区三区在线免费播放 | 精品一二线国产| 日韩美女久久久| 色网综合在线观看| 午夜不卡av在线| 久久精品欧美一区二区三区不卡 | 日本一区二区成人| 欧美日韩一本到| 国产精品一区二区三区乱码| 亚洲第一福利视频在线| 久久亚洲精华国产精华液| 色综合久久综合网欧美综合网| 中文字幕视频一区| 91精品国产色综合久久ai换脸| 性感美女久久精品| 亚洲欧美在线aaa| 久久免费看少妇高潮| 日韩一级完整毛片| 欧美性受极品xxxx喷水| 成人av动漫网站| 粉嫩在线一区二区三区视频| 另类调教123区| 精品综合久久久久久8888| 免费观看久久久4p| 久久精品国产亚洲5555| 一区二区三区在线免费观看| 亚洲手机成人高清视频| 午夜免费久久看| 亚洲一区二区三区四区在线观看| 国产精品亚洲第一区在线暖暖韩国| 7799精品视频| 欧美剧情片在线观看| 色av综合在线| 欧美日韩一区视频| 欧美日产国产精品| 欧美成人艳星乳罩| 国产午夜精品一区二区三区四区| 91在线精品一区二区| 成人午夜视频网站| 色av综合在线| 欧美亚日韩国产aⅴ精品中极品| 视频一区二区欧美| 亚洲精品videosex极品| 亚洲一二三四久久| 亚洲桃色在线一区| 一区二区三区四区精品在线视频| 精品黑人一区二区三区久久| 精品少妇一区二区三区在线视频| 国产成人精品综合在线观看 | 午夜一区二区三区视频| 亚洲欧美日韩国产另类专区| 亚洲欧洲美洲综合色网| 国产精品久久影院| 亚洲一区在线观看视频| 免费国产亚洲视频| 国产风韵犹存在线视精品| 99re6这里只有精品视频在线观看| 免费人成在线不卡| 国产一区二区视频在线| 99久久精品免费看国产| 91精品国产高清一区二区三区蜜臀| 国产成人精品亚洲日本在线桃色| 一区二区三区四区不卡在线| 日韩专区中文字幕一区二区| 精彩视频一区二区| 91影院在线免费观看| 日韩久久免费av| 尤物av一区二区| 国内精品免费**视频| 99久久国产综合精品色伊| 欧美性猛交xxxx乱大交退制版| 成人精品一区二区三区四区| 欧美在线短视频| 中文字幕国产精品一区二区| 久久精品国内一区二区三区| 欧美三级韩国三级日本三斤| 国产精品福利在线播放| 一区二区三区欧美在线观看| aa级大片欧美| 久久综合色天天久久综合图片| 欧美自拍丝袜亚洲| 91精品欧美福利在线观看| 欧美国产精品一区二区| 美女视频一区二区三区| 日本精品视频一区二区| 国产精品你懂的| 国产精品亚洲а∨天堂免在线| 日韩av午夜在线观看| 成人免费视频视频| 精品久久一区二区三区| 美女视频一区在线观看| 91黄视频在线观看| 欧美国产成人在线| 国产成人免费视频网站| 国产日韩高清在线| 成人av网址在线观看| 欧美国产日产图区| 99国产精品国产精品毛片| 亚洲国产精品成人综合| 国产91富婆露脸刺激对白| 26uuu另类欧美| 国产精品一级黄| 国产清纯白嫩初高生在线观看91 | 国产精品中文字幕一区二区三区| 韩国精品久久久| 日韩天堂在线观看| 亚洲午夜久久久久中文字幕久| 日韩精品一区第一页| 一本色道久久综合狠狠躁的推荐| 99精品视频在线观看| 欧美激情一区二区三区全黄| 日韩精品午夜视频| 日韩免费电影一区| 成人一级片在线观看| 亚洲欧洲性图库| 欧美喷水一区二区| 韩国v欧美v亚洲v日本v| 亚洲欧洲成人精品av97| 精品视频在线视频| 国产精品综合在线视频| 亚洲免费观看高清完整版在线观看熊| 五月天久久比比资源色| 日韩精品最新网址| jlzzjlzz亚洲女人18| 国产精品传媒入口麻豆| 色菇凉天天综合网| 精品一区二区精品| 18成人在线视频| 欧美一级黄色录像| 不卡大黄网站免费看| 日韩黄色片在线观看| 国产精品免费视频一区| 69久久99精品久久久久婷婷| 成人精品免费视频| 麻豆专区一区二区三区四区五区| 欧美三电影在线| 国产一区二区三区电影在线观看| 欧美日韩激情在线| 韩国成人在线视频| 樱桃视频在线观看一区| 日韩欧美国产一区二区三区| 97精品久久久久中文字幕| 日本亚洲三级在线| 亚洲欧美乱综合| 亚洲精品在线观| 欧美日韩精品免费观看视频| 成人一区二区在线观看| 美女网站一区二区| 午夜av电影一区| 亚洲欧美日韩综合aⅴ视频| 精品国产乱码91久久久久久网站| 亚洲摸摸操操av| 欧美日本一区二区三区四区| av在线不卡免费看| 国产在线观看一区二区| 亚洲国产精品一区二区www在线 | 精品一区二区在线看| 视频一区二区三区入口| 色呦呦国产精品| 蜜臀av亚洲一区中文字幕| 中文字幕一区二区三| 伊人开心综合网| 专区另类欧美日韩| 久久精品水蜜桃av综合天堂| 4438x成人网最大色成网站| 色综合色综合色综合| 国产一区二区在线观看免费 |