电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 网站运营-> 网站运营
用getstring提高ASP运行速度
作者:网友供稿 点击:23
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
许多asp程序员都有过执行数据库查询,然后将查询结果用html表格的形式显示出来的
经历吧.通常我们是这么做的:

<%
createconnection/recordset
populatedataintorecordsetobject
%>


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

如果查询结果很多,服务器解释你的aspscript将花费大量的时间,因为有许多的
response.write语句要处理.如果你将输出的全部结果放在一个很长的字符串里(从
<table>到</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"%>
<%optionexplicitgoodcodingtechnique

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>
</table>

</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></table>放在它的后面.这是因为我们的格式化字符串中并不含有这些
表格头尾所需的字符串.)

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·ASP.NET的安装与运行环境-.NET教程,Asp.Net开发
·运用.NET+SQL Server2005构建多层网站(3)-.NET教程,数据库应用
·JAVA写的四则混合运算-JSP教程,Java技巧及代码
·获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·Alexa 世界网站排名研究(下)-网站运营,搜索引擎推广
·运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用
·优化系统让Photoshop运行更流畅-网页设计,Photoshop
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发
·手工打造运算符重载过程-.NET教程,C#语言

最新文章
·MySQL服务器内部安全数据目录访问
·MySQL和SQL Server,到底选择谁?
·五种推广模式的优劣的比较
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·运用反射给实体赋值-.NET教程,Asp.Net开发
·大数运算(一)-.NET教程,评论及其它
·虚拟主机上asp.net运行权限不足问题及解决-.NET教程,Asp.Net开发
·ASP.NET底层架构探索之进入.NET运行时-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例实现-.NET教程,.NET Framework
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发




版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号