对数据库中的记录用上一条下一条显示(三)
程序员文章站
2022-04-02 23:02:33
三、bookmark/movenext/moveprevious例子让我们看一个asp程式码当中使用bookmark/movenext/moveprevious做到上一条下一条功能...
三、bookmark/movenext/moveprevious例子
让我们看一个asp程式码当中使用bookmark/movenext/moveprevious做到上一条下一条功能的例子。
譬如asp程式码rs15.如下:
<%
set conn1 = server.createobject("adodb.connection")
conn1.open "dbq="& server.mappath("ntopsamp.mdb") &";driver={microsoft access(小型网站之最爱) driver (*.mdb)};driverid=25;fil=ms access(小型网站之最爱);"
set rs2 = server.createobject("adodb.recordset")
sqlstr = "select * from 着作"
rs2.open sqlstr,conn1,1,1
bkstart = rs2.bookmark
bkend = rs2.bookmark + rs2.recordcount - 1
rs2.movenext
if request("sel") = "prev" then
rs2.bookmark = session("bookmark")
rs2.moveprevious
elseif request("sel") = "next" then
rs2.bookmark = session("bookmark")
rs2.movenext
end if
session("bookmark") = rs2.bookmark
%>
<table colspan=8 cellpadding=5 border=0>
<tr>
<td align=center bgcolor="#008080"><font color="#ffffff">书名</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">出版</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">图片</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">简介</font></td>
<tr>
<td bgcolor="f7efde" align=center><%= rs2("书名")%></td>
<td bgcolor="f7efde" align=center><%= rs2("出版")%></td>
<td bgcolor="f7efde" align=center><%= rs2("图片")%></td>
<td bgcolor="f7efde" align=center><%= rs2("简介")%></td>
</tr>
</table>
<% = session("bookmark") %>
<% if session("bookmark") > bkstart then %>
<a href=rs15.asp?sel=prev>上一条</a>
<% end if %>
<% if session("bookmark") < bkend then %>
<a href=rs15.asp?sel=next>下一条</a>
<% end if %>
<% rs2.close %>
以上的 asp程式码rs15.asp,在用户端使用,浏览执行的结果,显示上一条下一条的功能。
由session("bookmark")储存这个使用者recordset 的bookmark(书签)位置,当按下 [上一条] 超级连接时,由<a href=rs15.asp?sel=prev>上一条</a>,将sel设定为prev,并重新执行rs15.asp的asp码。由以下的程式部份,首先将bookmark 属性设为所设定书签记号的名称session("bookmark")回到上次书签的位置,然后使用moveprevious移动到上一条的位置:
if request("sel") = "prev" then
rs2.bookmark = session("bookmark")
rs2.moveprevious
elseif request("sel") = "next" then
rs2.bookmark = session("bookmark")
rs2.movenext
end if
session("bookmark") = rs2.bookmark
然后使用session("bookmark") = rs2.bookmark设定书签,session("bookmark")储存书签记号的名称。
当按下 [下一条] 超级连接时,由<a href=rs15.asp?sel=next>下一条</a>,将sel设定为next,并重新执行rs15.asp的asp码。由以上的程式部份,回到上次书签的位置,然后使用movenext移动到下一条的位置。
由<% = session("bookmark") %>显示书签的位置,请注意第一条记录的位置并非为0而是1792,因此我们必须取得第一条和第末条的书签位置值,以判断是否要显示 [上一条] [下一条] 超级连接。
为了判断是否要显示 [上一条] [下一条] 超级连接,由以下的程式部份,我们设定了两个书签,由bkstart = rs2.bookmark设定第一条的位置,由bkend = rs2.bookmark + rs2.recordcount - 1设定第末条的位置:
让我们看一个asp程式码当中使用bookmark/movenext/moveprevious做到上一条下一条功能的例子。
譬如asp程式码rs15.如下:
<%
set conn1 = server.createobject("adodb.connection")
conn1.open "dbq="& server.mappath("ntopsamp.mdb") &";driver={microsoft access(小型网站之最爱) driver (*.mdb)};driverid=25;fil=ms access(小型网站之最爱);"
set rs2 = server.createobject("adodb.recordset")
sqlstr = "select * from 着作"
rs2.open sqlstr,conn1,1,1
bkstart = rs2.bookmark
bkend = rs2.bookmark + rs2.recordcount - 1
rs2.movenext
if request("sel") = "prev" then
rs2.bookmark = session("bookmark")
rs2.moveprevious
elseif request("sel") = "next" then
rs2.bookmark = session("bookmark")
rs2.movenext
end if
session("bookmark") = rs2.bookmark
%>
<table colspan=8 cellpadding=5 border=0>
<tr>
<td align=center bgcolor="#008080"><font color="#ffffff">书名</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">出版</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">图片</font></td>
<td align=center bgcolor="#008080"><font color="#ffffff">简介</font></td>
<tr>
<td bgcolor="f7efde" align=center><%= rs2("书名")%></td>
<td bgcolor="f7efde" align=center><%= rs2("出版")%></td>
<td bgcolor="f7efde" align=center><%= rs2("图片")%></td>
<td bgcolor="f7efde" align=center><%= rs2("简介")%></td>
</tr>
</table>
<% = session("bookmark") %>
<% if session("bookmark") > bkstart then %>
<a href=rs15.asp?sel=prev>上一条</a>
<% end if %>
<% if session("bookmark") < bkend then %>
<a href=rs15.asp?sel=next>下一条</a>
<% end if %>
<% rs2.close %>
以上的 asp程式码rs15.asp,在用户端使用,浏览执行的结果,显示上一条下一条的功能。
由session("bookmark")储存这个使用者recordset 的bookmark(书签)位置,当按下 [上一条] 超级连接时,由<a href=rs15.asp?sel=prev>上一条</a>,将sel设定为prev,并重新执行rs15.asp的asp码。由以下的程式部份,首先将bookmark 属性设为所设定书签记号的名称session("bookmark")回到上次书签的位置,然后使用moveprevious移动到上一条的位置:
if request("sel") = "prev" then
rs2.bookmark = session("bookmark")
rs2.moveprevious
elseif request("sel") = "next" then
rs2.bookmark = session("bookmark")
rs2.movenext
end if
session("bookmark") = rs2.bookmark
然后使用session("bookmark") = rs2.bookmark设定书签,session("bookmark")储存书签记号的名称。
当按下 [下一条] 超级连接时,由<a href=rs15.asp?sel=next>下一条</a>,将sel设定为next,并重新执行rs15.asp的asp码。由以上的程式部份,回到上次书签的位置,然后使用movenext移动到下一条的位置。
由<% = session("bookmark") %>显示书签的位置,请注意第一条记录的位置并非为0而是1792,因此我们必须取得第一条和第末条的书签位置值,以判断是否要显示 [上一条] [下一条] 超级连接。
为了判断是否要显示 [上一条] [下一条] 超级连接,由以下的程式部份,我们设定了两个书签,由bkstart = rs2.bookmark设定第一条的位置,由bkend = rs2.bookmark + rs2.recordcount - 1设定第末条的位置: