您现在的位置:计算机技术学习网 > 技术中心 > WEB编程 > ASP >

数据库记录分页技术与实现

来源:网络收集 责任编辑:栏目编辑 发表时间:2013-07-02 02:29 点击:
面对与日俱增的访问量,许多Internet网站的数据库服务器越来越不堪重负。本文介绍的数据库记录分页技术,可以显著提高网站运行效率。

注意:

首先,从头到尾读数据库记录来确定要显示的页面及记录的方法并不可取,因为每次均需从数据库中读取所有记录,丝毫没有解决数据库服务器负担过重的问题;

其次,将数据库记录存入到内存数组、临时数据表或临时文件中再分页显示的方法也不理想,虽然响应效率可能有所提高,但必须为每个用户分配足够的内存和磁盘空间。

第三,rs.Open qString, conn, adOpenStatic, adLockReadOnly, adCmdText,这里必须使用adOpenStatic或adOpen-Dynamic游标类型,而不能使用前向游标,否则会使RecordCount等属性或方法返回的值不正确。

第四,SQL语句中必须使用Order By子句指定一个排序字段,以便保持各页记录的相对位置不变,否则每页显示的内容会变得杂乱无章。

<% @ LANGUAGE="VBScript" %>

<%
Option Explicit
Response.Buffer = True

Const adUseClient = 3
Const adCmdText = 1

游标类型
Const adOpenForwardOnly = 0
Const adOpenKeyset = 1
Const adOpenDynamic = 2
Const adOpenStatic = 3

加锁类型
Const adLockReadOnly = 1
Const adLockPessimistic = 2
Const adLockOptimistic = 3
Const adLockBatchOptimistic = 4


rs.PageSize = pagesize
rs.CacheSize = pagesize
rs.CursorLocation = adUseClient

rs.Open qString, conn, adOpenForwardOnly, adLockReadOnly, adCmdText

strPageCount = rs.PageCount
If 1 > strPageCurrent Then strPageCurrent = 1
If strPageCurrent > strPageCount Then strPageCurrent = strPageCount

numrecs = rs.RecordCount

rs.AbsolutePage = strPageCurrent

Do While not rs.EOF and (I < pagesize)
I = I + 1
rs. MoveNext
Loop

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • WAP常见问题问答大全(四)
    • ASP开发必备:WEB打印代码大全
    • ASP调用系统ping命令
    • asp缓存技术
    • ASP教程:第三篇 ASP基础
    • 用ASP+XML打造留言本(4)
    • 关于ASP Recordset 分页出现负数解决方法及建议
    • 用asp怎样编写文档搜索页面(5)
    • ASP处理多关键词查询实例代码
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1