侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

来自CSDN的"无限流"分页程序

技术  /  管理员 发布于 7年前   305

以下是代码片段: 
'******************************************************************  
'** 本程序名:"无限流"分页程序  
'** 作者:Arbiter(AAsx)  
'** 版本:Million Level  
'**  
'** QQ:22222xx  
'** Email:[email protected]  
'** http://www.imagecity.org/  
'******************************************************************  
'**  
'** 【作者的话】  
'**  
'** 分页程序无疑是许多网络程序功能中一个比较麻烦的东西,事实上现在  
'** 为止绝大部分人还是在使用传统的分页方法(Rs.PageSize=xx),而了解  
'** 数据库操作的人都知道,这种传统方式有个弊端:第一次打开页面时,  
'** 它会预读所有的记录集,这当在数据大的时候,这将是致命的,而且接  
'** 下来的翻页速度也会非常慢,很占用资源。对于十万数量级以上的数据  
'** 库这种传统分页方式已经显得非常无力,更别说百万级了(根本没法操  
'** 作)。基于这种原因,促使我做了本程序。  
'**  
'** 【程序功能】  
'**  
'** 针对大型的数据库进行分页操作,理想的可操作的数据记录量在200万  
'** 以内(Max Level版将无数量限制,且无论数据库多大,翻页速度都是  
'** 不变),这是Million Level版分页程序在赛扬1G、内存512、win2k环  
'** 境下的测试数据:  
'**  
'** SQLserver 2k + 10万条记录 + 每页显示20条:  
'** 平均翻页速度:45ms  
'** SQLserver 2k + 100万条记录 + 每页显示20条:  
'** 平均翻页速度:350ms  
'**  
'**  
'** 【分页原理】  
'**  
'** 本程序不再使用Rs.PageSize的方式分页,连接数据库的游标类型  
'** 也不是使用conn,1,x,而是conn,0,1,这应是最快的游标类型了,不要  
'** 以为这样会使程序变得复杂,相反,程序非常简单,如果你看不明白,  
'** 应该是我的编程风格你不习惯,而非程序复杂。  
'** "无限流"分页的中心是:每页只读出需要显示的记录,不再象传统  
'** 分页程序预读全部的数据,这正在本程序最大的优点--占用资源少,同  
'** 理速度也得到非常大的提升,特别在数据量越大的时候,它的速度优势  
'** 越明显(100万记录才350ms左右)。  
'** 当程序执行后,使用CurcorBegin和CurcorEnd记录显示的第一条记  
'** 录和最后一条记录的ID值,作为下一次翻页的标记,然后利用Top xx取  
'** 出需要的数据显示,同时又再对ID值进行记录。  
'**  
'** 【结 言】  
'**  
'** 本程序为共享版,提供给各程序爱好者研究使用,若要转载、散播、修  
'** 改或作其他用途,请尊重作者的辛劳,注明出处。  
'** 如果本程序中有错漏、非最优化等缺点,请到www.csdn.net的Web开发/  
'** ASP栏目中发表讨论,为了中国软件事业的发展,请不要固步自封:)  
'**  
'********************************************************************    
Option Explicit  
'Response.Flush  
Dim BeginTime,EndTime  
BeginTime=Timer  
Dim conn,SQLstr,Rs,DefRecordNum,CursorBegin,CursorEnd,CurPageNum,hav  
DefRecordNum=20  
'--------------获取相关参数----------  
If Request("CursorBegin")="" Then CursorBegin=0 Else CursorBegin=Request("CursorBegin")  
If Request("CursorEnd")="" Then CursorEnd=0 Else CursorEnd=Request("CursorEnd")  
If Request("CurPageNum")<>"" Then  
CurPageNum=CLng(Request("CurPageNum"))  
If CurPageNum<=0 Then CurPageNum=1  
Else  
CurPageNum=1  
End If  
hav=Request("hav")  
If hav="" Then hav="next"  
'----------------End-----------------  
'------------显示翻页内容函数--------  
Function TurnPageFS(DispRecordNum)  
Dim n  
While Not(Rs.Eof) And n n=n+1  
Response.Write ""&_  
""&Rs(0)&""&_  
""&Rs(1)&""&_  
""&Rs(2)&""&_  
""&Rs(3)&""&_  
""&Rs(4)&""&_  
""&Rs(5)&""&_  
""  
If n=1 Then CursorBegin=Rs(0)  
If n=DefRecordNum Or Rs.Eof Then CursorEnd=Rs(0)  
Rs.MoveNext  
Wend  
End Function  
'-------------连接数据库-------------  
Set conn=Server.CreateObject("Adodb.Connection")  
'SQLstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.Mappath("mldata.mdb")  
SQLstr="Driver={SQL Server};server=arbiter;uid=arbiter;pwd=123456;database=mldata"  
conn.Open SQLstr  
'---------统计总记录数/总页数---------  
'-PS:推荐使用count(ID),ID为自动编号且索引,否则速度有可能大打折扣  
'-PS:此统计是本程序中最耗资源的一部分,如果取消这段程序,速度会快上10倍左右  
Dim TotalRecords,TotalPages  
SQLstr="Select count(ID) As RecordSum From ABC"  
Set Rs=conn.Execute(SQLstr,0,1)  
TotalRecords=Rs("RecordSum")  
TotalPages=Abs(Int(TotalRecords/DefRecordNum*(-1)))  
Rs.Close  
Set Rs=Nothing  
'--------根据hav选择相应的SQL字串-----  
Select Case(hav)  
Case "back"  
CursorEnd=CursorBegin  
SQLstr="Select Top "&DefRecordNum&"_  
ID,Title,FileName,K,ImgSize,NameSon _  
From ABC Where ID<"&CursorBegin&_  
" And ID In (Select Top "&DefRecordNum_  
&" ID From ABC Where ID<"&CursorBegin_  
&" Order by ID DESC) Order by ID"  
Case "next"  
SQLstr="Select Top "&DefRecordNum_  
&" ID,Title,FileName,K,ImgSize,NameSon From ABC Where ID>"&CursorEnd&_  
" Order by ID"  
End Select  
Set Rs=conn.Execute(SQLstr,0,1)  
%>  



  

  
td,br,div,p,body {font-size:12px}  

  

   

首页 上一页   
下一页   

  

   
ID  
Title  
FileName  
大小  
尺寸  
类别      

首页 上一页   下一页  

function turnpage(func){  
var CurPageNum=; //取得当前页码  
var CursorBegin=; //取得第一个显示的记录的ID值  
var CursorEnd=; //取得最后一个显示的记录的ID值  
var TotalPages=; //取得页面总数   
var BackUrl='mllist.asp?CurPageNum='+(CurPageNum-1)+'&CursorBegin='+CursorBegin+'&CursorEnd='+CursorEnd+'&hav=back';  
var NextUrl='mllist.asp?CurPageNum='+(CurPageNum+1)+'&CursorBegin='+CursorBegin+'&CursorEnd='+CursorEnd+'&hav=next';  
if(CurPageNum<=1 && func=='back'){  
location.href='';  
}else if(CurPageNum>=TotalPages && func=='next'){  
location.href='';  
}else if(func=='back'){  
location.href=BackUrl;  
}else if(func='next'){  
location.href=NextUrl;  
}  
}


  • 上一条:
    1ting的歌词同步,所用到的代码
    下一条:
    封装的一个播放器wmv
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 2024.07.09日OpenAI将终止对中国等国家和地区API服务(0个评论)
    • 2024/6/9最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 国外服务器实现api.openai.com反代nginx配置(0个评论)
    • 2024/4/28最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2017-09
    • 2018-01
    • 2018-07
    • 2018-08
    • 2018-09
    • 2018-12
    • 2019-01
    • 2019-02
    • 2019-03
    • 2019-04
    • 2019-05
    • 2019-06
    • 2019-07
    • 2019-08
    • 2019-09
    • 2019-10
    • 2019-11
    • 2019-12
    • 2020-01
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-12
    • 2024-02
    • 2024-04
    • 2024-05
    • 2024-06
    • 2025-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客