游客:
注册
|
登录
|
帮助
网友俱乐部
»
网络编程
»
ASP教程
» ASP基础实例教程之八个小时打造新闻发布系统二
网友生活网
|
网友学堂
如何获得金币?
诚招斑竹
IP归属地查询 PR查询 收录查询 whois查询
免费超短2级域名,your.jpy.cc
传世私服
|
传奇世界私服
注册亚洲交友中心,找个人来同居吧!
免费存储空间,免费网络硬盘
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
打印
|
推荐
|
订阅
|
收藏
标题: ASP基础实例教程之八个小时打造新闻发布系统二
ljjk5
元帅
UID 46706
精华
1
积分 99426
帖子 49690
威望 554
金币 48489
热心 505
阅读权限 100
注册 2007-2-25
状态 离线
#1
使用道具
发表于 2007-11-20 16:35
资料
个人空间
主页
短消息
加为好友
ASP基础实例教程之八个小时打造新闻发布系统二
(第2个小时)
现在来学把数据库的信息输出来,并实现分页。有点复杂。。
(一)首先有必要和大家详细说一下recordset对象的成员。。有关分页技术的几个成员我在这里
详细解说一下。
Pagesize属性:指示Recordset中一页所包含的记录数。默认值为10
Pagecount属性:指示Recordset对象包含的数据页数
AbsolutePage属性:指示从1到Recordset对象所含页数的长整型。通俗的说就是如果数据库有
4页。那么 AbsolutePage就是1,2,3,4
(二)下面先建立一个后台文件admin.asp
代码如下
CODE:
<!--#include file="conn.asp"-->
<%
exec="select * from aa order by id desc"
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
%>
<%
rs.pagesize=2
pagecount=rs.pagecount
page=int(request("page"))
if page<=0 then page=1
if request.querystring("page")="" then
page=1
end if
rs.absolutepage=page
%>
<table width="83%" border="1" align="center" cellpadding="0" cellspacing="0" bordercolorlight="#000000" bordercolordark="#FFFFFF">
<tr >
<td height="27" colspan="5" align="center"><a href="add.asp" target="_blank">添加新闻</a></td>
</tr>
<tr>
<td width="68" height="24" align="center">编号</td>
<td width="179" align="center">标题</td>
<td width="202" align="center">时间</td>
<td colspan="2" align="center">管理</td>
</tr>
<tr>
<%
for i=1 to rs.pagesize
if rs.Eof then
exit for
end if
%>
<td height="25" align="center"><%=rs("id")%></td>
<td><%=rs("title")%></td>
<td><%=rs("time")%></td>
<td width="80" align="center"><a href="modify.asp?id=<%=rs("id")%>" >编辑</a></td>
<td width="82" align="center"><a href="del.asp?id=<%=rs("id")%>" >删除</a></td>
</tr>
<%
rs.movenext
next
%>
<%
rs.close
set rs=nothing
conn.close
set conn=nothing
%>
</table>
<% for i=1 to pagecount %>
<a href="admin.asp?page=<%=i%>"><%=i%></a>
<%next%>
代码解释:
(1)<%
exec="select * from aa order by id desc "
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
%>
上面的代码是创建一个recordset对象。。该对象是用来打开数据库中的表的。。也就是打开aa
exec="select * from aa order by id desc " 这句的意思是查找表aa中所有信息并倒序排列
信息. *号表示aa中所有的信息 order by id 就是aa中id字段 desc 是倒序的意思
rs.open exec,conn,1,1 这句话的意思是用recordset对象来打开conn中的表
(2)
<%
rs.pagesize=2
pagecount=rs.pagecount
page=int(request("page"))
if page<=0 then page=1
if request.QueryString("page")="" then
page=1
end if
rs.absolutepage=page
%>
这段代码相当重要。大家觉的里面有些单词很熟悉是不是。。
rs.这个的意思是前面 rs=server.createobject("adodb.recordset")
rs就是recordset对象
在很多语言中。rs.的逗号的中文意思是“的”。
那么rs.的解释就是 recordset对象的
rs.pagesize=2 中文解释就是recordset对象的pagesize等于2 pagesize的意思是一页显示多少条信息
pagecount=rs.pagecount 定义pagecount等于recordset对象的pagecount
page=int(request("page")) 接收到的page是整数型
if page<=0 then page=1 如果page小于等于0 page就等于1
if request.QueryString("page")="" then 如果接收到的page是空。
page=1 page等于1
end if 结束
rs.absolutepage=page recordset对象的absolutepage等于page
我只是把每一句语句的意思解释了一遍。。
这里每一句语句都和其它语句有关联。。看不懂也不要泄气。。
因为这个东西是不能一下子学会的。。要看上一段时间。。慢慢理解。。
(3)
<%
for i=1 to rs.PageSize
if rs.EOF then
exit for
end if
%>
上面语句是循环语句。。实现数据库信息的输出
for i=1 to rs.PageSize 每次输出两条信息。PageSize 在前面已经定义为2
if rs.EOF then 如果扫描到数据表中最后一条就结束 exit for
(4)
<%
rs.movenext
next
%>
rs.movenext 这句是游标向下指的意思
<%
rs.close
set rs=nothing
conn.close
set conn=nothing
%>
关闭数据库的意思
(5)
<% for i=1 to pagecount %>
<a href="admin.asp?page=<%=i%>"><%=i%></a>
<%next%>
这句语句的作用是显示页数。。就是显示1,2,3,4 。。我们点2就跳到第2页的内容
这段语句用到了之前定义的pagecount=rs.pagecount 指示Recordset对象包含的数据页数
也就是pagecount能记录数据表的数据分成了几页
<% for i=1 to pagecount %>那么这句的意思是显示1,2,3,4。。。。
<a href="admin.asp?page=<%=i%>"><%=i%></a>这句理解起来有点麻烦。。
?号是连接字符。admin.asp?page是admin.asp中的page 这里的page就是先前
定义的 page=int(request("page"))
<a href="admin.asp?page=<%=i%>">整句的意思就是为每个显示的数字添加连接。。
<%=i%>这里是指1,2,3,4。。。所以我们点任意一个数字就会跳转到该页的内容
<%next%> 指向下一个
完成后台管理的主页了。。我们继续走吧。。
网友
ljjk5
签名 - 网友社区
===
[广告]
免费域名(Free Subdomain)
免费空间(Free hosting)
PR查询(Google Pagerank)
投票
交易
悬赏
活动
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
个人空间管理
基本概况
流量统计
客户软件
发帖量记录
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计
当前时区 GMT+8, 现在时间是 2008-11-23 20:06
信产部ICP备案:
京ICP备05066424号
北京市公安局网监备案:1101050648号
Powered by
Discuz!
5.5.0
TOP
清除 Cookies
-
联系我们
-
网友俱乐部
-
Archiver
-
WAP