学习ASP时,必不可少的就是用到增、删、改、查四大操作。最麻烦的就是把数据库里的数据输出到客户端。数据很少的时候,比如一个数据库中就有几条,这样直接输出就可以了。但如果数据很多的时候,只靠SQL的优化就不能完成查询了。
那么,怎样才能优化查询结果呢?也许我们会想到分页,对,ASP内置组件给我们提供了RecordSet 对象,我们可以利用这个对象的几个属性,就能很方便地得到自己想要的结果了。
大部分学过ASP的朋友都能写出分页代码,那好吧,我们也这样写。
假设我们已经连上数据库。
中国.站.长站
<!--#include file="conn.asp" --> ''把数据库连接字符串包含过来
rs.pagesize=10 ''设置每页显示10条记录
page=cint(request("page")) ''使用queryscring获取当前前数
if page<1 then page=1 ''当页数小于1时显示第一页
if page>rs.pagecount then page=rs.pagecount ''当页数大于最后一页时显示最后一页
myself=request.serververiables("path_info") ''获取当前页的相对路径
if page>1 then rs.absolutepage=page ''如果页数大于1则显示绝对页数
''循环输出页数
for i=1 to rs.pagecount
if rs.eof then exit for ''记录在最后一条的后面退出循环
中国站.长.站
if i=page then
response.write " | "&i&" | "
else
response.write " | <a href="&myself&"/page="&i&">"&i&"</a> | "
end if
end for
''循环输出记录条数
for i=1 to rs.pagesize
if rs.eof then exit for
response.write rs("id")
Chinaz.com
response.write rs("user")
response.write rs("pwd")
rs.movenext
end for
''关闭数据库以及连接
rs.close
conn.close
set conn=nothing
set rs=nothing
但是,这样并不能达到最佳优化。如果我们在page后面这样输入:page=adsf 。我们就会看到出错结果,因为cint函数不能把字符串转换为整数。有时你会看到没有错误,那是因
