首 页文章中心客户留言enfullPDA完全版游戏天空全方位下载繁體中文
设为首页
加入收藏
联系我们
您当前的位置:技术文章大全 -> 文章中心 -> 技术开发 -> ASP学院 -> 文章内容 退出登录 用户管理
栏目导航
· .Net专栏 · Script
· ASP学院 · PHP学院
· Web服务器 · XML学院
· SQL学院 · JSP学院
· 程序开发 · 数据库
热门文章
· 个人实习总结
· “八荣八耻”演讲稿...
· 毕业论文格式范文
· 八荣八耻 内容|八荣...
· 党校学习个人总结
· “八荣八耻”心得体...
· 教育实习总结报告
· 社会主义荣辱观教育...
· 市场营销系毕业实习...
· 党课学习思想汇报
相关文章
· [图文] 清理第三方插件 大幅...
· [图文] 路由协议一样影响网...
· 只需四步就能提高Gh...
· 一个使用getopt()函...
· PHP3,PHP4,ASP运行...
· 例子:用getenv函数...
· 从外国的一个网站上...
· 用GetString来提高A...
· 妙用GetSystemMetri...
· 利用getwindows屏蔽...
用getstring提高ASP运行速度
作者:佚名  来源:不详  发布时间:2006-1-8 18:26:09  发布人:admin

减小字体 增大字体

许多asp程序员都有过执行数据库查询,然后将查询结果用html表格的形式显示出来的
经历吧.通常我们是这么做的:

<%
'createconnection/recordset
'populatedataintorecordsetobject
%>


<table>
<%dowhilenotrs.eof%>
<tr>
<td><%=rs("field1")%></td>
<td><%=rs("field2")%></td>
...
</tr>
<%rs.movenext
loop%>


如果查询结果很多,服务器解释你的aspscript将花费大量的时间,因为有许多的
response.write语句要处理.如果你将输出的全部结果放在一个很长的字符串里(从
<table>到),那么服务器只需解释一遍response.write语句,速度就会快得
多.微软公司里的一些能干的家伙已经将想法变成了现实.(注意,这是一个ado2.0
才有的特性.如果你还在使用ado1.5话,可以在
http://www.microsoft.com/data/download.htm免费下载ado2.0)

有了getstring方法,我们就可以仅用一个response.write来显示所有的输出了,它就
象是能判断recordset是否为eof的do...loop循环.

getstring的用法如下(所有的参数都是可选的):

string=recordset.getstring(stringformat,numrows,columndelimiter,
rowdelimiter,nullexpr)

要从recordset的结果里生成html表格,我们只需关心getstring的5个参数中的3个:
columndelimiter(分隔记录集的列的html代码),rowdelimiter(分隔记录集的行的
html代码),和nullexpr(当前记录为空时应生成的html代码).就象你在下面生成
html表格的例子里所看到的那样,每列用<td>...</td>分隔,每行用<tr>...</tr>分
隔.来看看例子的代码吧.

<%@language="vbscript"%>
<%optionexplicit'goodcodingtechnique

'establishconnectiontodb
dimconn
setconn=server.createobject("adodb.connection")
conn.open"dsn=northwind;"

'createarecordset
dimrs
setrs=server.createobject("adodb.recordset")
rs.open"select*fromtable1",conn

'storeouronebigstring
dimstrtable
strtable=rs.getstring(,,"</td><td>","</td></tr><tr><td>","&nbsp;")%
>

<html>
<body>


<table>
<tr><td>
<%response.write(strtable)%>
</tr></td>


</body>
</html>
<%

'cleanup!
rs.close
setrs=nothing
conn.close
setconn=nothing
%>

strtable字符串用于存放我们从"select*fromtable1"结果生成的html表格的代
码.html表格的每列之间都将有</td><td>的html代码,每行之间的html代码是
</td></td><tr><td>.getstring方法将输出正确的html代码并存放在strtable中,
这样我们只需一行response.write便可以输出数据集中的所有记录.让我们来看个简
单的例子,假设我们的查询结果返回了以下的行和列:

col1col2col3
row1bobsmith40
row1edfrank43
row1suevoid42

那么getstring语句返回的字符串将是:

bob</td><td>smith</td><td>40</td><td></td></tr><tr><td>ed...

说实话,这个字符串看上去冗长而杂乱,但它就是我们想要的html代码.(注意看,我们
在手工书写的html代码中,将<table><tr><td>放在response.write的前面,将
</td></tr>放在它的后面.这是因为我们的格式化字符串中并不含有这些
表格头尾所需的字符串.)
[] [返回上一页] [打 印] [收 藏]
上一篇文章:Zend Optimizer 配置指南
下一篇文章:发送mime邮件类
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
友情连接 - 网站地图 -