欢迎光临
我们一直在努力

利用ASP实现对表的分页浏览(上)-ASP教程,ASP应用

建站超值云服务器,限时71元/月

大家都知道,asp有着强大的数据库操作能力,这与她能方便的调用activex对象是密不可分的。下面我给大家介绍一种asp利用ado对象实现对数据库记录分页显示的方法。以下代码均在win98+pws+msaccess环境下通过。 

  在这里我主要通过ado对象集中的recordset对象来实现各种数据库操作的。先介绍几个用于分页显示的recordset属性。 

    pagesize:每页显示的记录数。 

    pagecount:根据用户设好的pagesize和表中的总记录数,系统自动算出总页数。 

    recordcount:表中的总记录数。 

    absolutepage:表示当前页码。如将absolutepage属性设为3,则当前记录移至第3页第1条(也就是第31条)。 

  看到recordset有了这几个属性后,相信大家也都觉得做一个分页显示的程序是很简单的。下面讲一下思路,所有实现这一功能的代码都放在display.asp中,按执行的顺序分别是:打开数据库及表、读取用户要求的显示方式、设定好pagesize和absolutepage、将内容输出到浏览器、设定好导航条。以下是代码: 

<%—————————打开数据库及表 
set conn=server.createobject(“adodb.connection”) 
filepath=server.mappath(“abc.mdb”) ——-假设数据库文件是”abc.mdb” 
conn.open “driver={microsoft access driver (*.mdb)};dbq=” & filepath 
set rs=server.createobject(“adodb.recordset”) 
rs.open “main”,conn,3,2 ——-假设表的名字是”main” 
%> 
<%—————————读取用户要求的显示方式(通过参数传递) 
line=cint(request(“line”)) 
page=cint(request(“page”)) 
%> 
<%—————————按用户要求设定好显示方式 
rs.pagesize=line 
rs.absolutepage=page 
%> 
<%—————————显示内容%> 
<table width=”100%” border=”1″> 
<tr> 
<%for i=0 to rs.fields.count-1%> 
<td><%=rs.fields(i).name%></td> 
<%next%> 
</tr><%——-以上部分显示表头,即字段名%> 
<%for i=1 to rs.pagesize%> 
<tr> 
<%for j=0 to rs.fields.count-1%> 
<td><%=rs.fields(j).value%></td> 
<%next%> 
</tr> 
<%rs.movenext%> 
<%if rs.eof then exit for%> 
<%next%><%——-以上部分显示表的内容%> 
</table> 

<%—————————导航条%> 
<table width=100% ><tr> 
<td> 
<%if page<>1 then%> 
<a href=display.asp?page=1&line=<%=line%>>第一页</a> 
<%else%>第一页<%end if%> 

</td> 
<td> 
<%if page>1 then%> 
<a href=display.asp?page=<%=page-1%>&line=<%=line%>>前一页</a> 
<%else%>前一页<%end if%> 
</td> 
<td> 
<%if page<rs.pagecount then%> 
<a href=display.asp?page=<%=page+1%>&line=<%=line%>>下一页 
<%else%>下一页<%end if%> 
</td> 
<td> 
<%if page<>rs.pagecount then%> 
<a href=display.asp?page=<%=rs.pagecount%>&line=<%=line%>>最后一页</a> 
<%else%>最后一页<%end if%> 
</td><%——-以上四项都需要进行判断:如果在第一页就不提供“第一页”和“前一页”的链接 
——-如果在最后一页就不提供“最后一页”和“后一页”的链接%> 
<td> 
<form method=”post” action=”display.asp?line=<%=line%>”> 
请输入页码:<input type=”text” name=”page” size=”3″ value=”<%=page%>”> 
</form> 
</td> 
<td> 
<form method=”post” action=”display.asp?page=<%=page%>”> 
请设定每页<input type=”text” name=”line” size=”3″ value=”<%=line%>”>行 
</form> 
</td><%——-因为两个表单都只有一个表单域,所以没有提供发送按钮,直接打回车就行了%> 
<td> 
第<%=page%>页/总<%=rs.pagecount%>页 
</td> 

</tr></table> 

  这只是一个最基本的程序,没有进行优化处理,也还有一些bug,下面我们一起来使它更“完美”一些。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 利用ASP实现对表的分页浏览(上)-ASP教程,ASP应用
分享到: 更多 (0)