小女巫 发表于 2015-1-16 23:34:29

ASP网站制作之数据分页办法新思绪,速率十分快

结论:和PHP一样,ASP简单而易于维护,很适合小型网站应用,通过DCOM和MTS技术,ASP甚至还可以完成小规模的企业应用,但ASP的致命缺点就是不支持跨平台的系统,在大型项目开发和维护上非常困难。分页|数据|速率这篇文章要到达的目标就是,完成年夜数据分页扫瞄并最优化速率。

创建一个web使用,分页扫瞄功效必不成少;这个成绩也是久长以来最广泛的成绩,今朝也失掉了较好的办理,个中象ASP程序的分页算法有良多,好比利用ado工具的PageSize这些属性,按纪录总数盘算页,然后跳转纪录集再输入;也有编写存储历程完成分页数据,这些方面各有优弱点,以下自己先容一种使用实践项目中速率十分快的分页算法;

关头点:SQL(用TOP和主动编号完成)
页面剧本(扫瞄器回退功效)

情况:
IIS/SQLServer/Access
表布局:
createtable内容表(
主动编号IDENTITY(int,1,1)notnull,
分类编码varchar(20)null,
题目varchar(255)NULL,
内容varchar(4000)null,
工夫datetimenull,
)

完成道理:
这个表设定了主动编号字段,这个字段的特征就是天生不反复的整形,包含删除纪录后该字段仍旧坚持‘流水性’(注:一般在体系表建立中,这类字段的使用很少,由于编号不克不及自在办理,但在这里利用它,次要是想在文章中省略编号保护的代码)。

分页:
那末第一步,就是查询一个页的数据;假如有100条记录,按20纪录一页,那末一般的分页算法就是“页总数=总纪录除分页的把持数[不足数的话,页总数加一]”,如许的做法就招致必需发生一切纪录的一个年夜纪录集;从而,又有人提出了用存储历程的分页算法,前者是asp剧本发生年夜纪录集,如许速率相称慢,后者是杀鸡用牛刀,固然我常常写存储历程,但依据我的思绪会发明写存储历程完整过剩。

在SQL中,很多刚打仗它的伴侣都晓得Top润色关头字的感化;比方:selectTOP1*fromtable1--如许就完成从Table1表前往只要一笔记录的纪录集那末分页优化的终极目标就是制止发生过年夜的纪录集,经由过程TOP便可完整把持;如今查询表应当是selectTop20主动编号,题目,内容,工夫from内容表。

但如今另有个成绩,就是怎样定位,Top不成能主动给我们定位输入某个页,这就计划到了where从句,依据一个特定前提输入准确的内容;注重:纪录的orderby排序长短常主要的,这个决意了这个算法的成败;

这里的演示是DESC体例,倒序分列,好比网站的软件更新,就是比来的更新放最后面,而这个就是倒序体例。

OK,上面来看看实践代码,起首要断定是不是为肇端页。


dimstrSQL,i,endID,isBeginPage
constCnt_PageSize=20界说每页纪录的巨细
经由过程反省扫瞄器传送的Page参数的值来判别是不是为进进下一页的操纵
isBeginPage=isEmpty(request("Page"))orrequest("Page")=""orrequest("Page")"next"
这里是分页的中心
ifisBeginPagethen假如是肇端页
查询=列出分类编码即是参数flbm的纪录,按倒序分列,并只列出前Cnt_PageSize笔(Cnt_PageSize是常量界说,好比20)
strSQL="selectTOP"&Cnt_pageSize&"主动编号,题目,内容,工夫from内容表where分类编码="&TRIM(SQLEncode(request("flbm")))&"orderby主动编号desc"
else假如不是肇端页
ifrequest("Page")="next"then这里如许写是为了增强代码的体现,假如参数为next,则暗示取下页内容
查询=列出分类编码即是参数flbm的纪录而且要小于主动编号endID(endID也是参数),并倒序分列,并只列出前Cnt_PageSize笔(Cnt_PageSize是常量界说,好比20)
strSQL="selectTOP"&Cnt_pageSize&"主动编号,题目,内容,工夫from内容表where分类编码="&TRIM(SQLEncode(request("flbm")))&"and主动编号<"&request("endID")&"orderby主动编号desc"
Endif
endif

翻开数据毗连实行SQL并创建纪录集
setrs=Cnn.Execute(strSQL)
ifnotrs.Eofthen这里写进判别是不是为Eof能够不要,可是,在这里却有它的特别意义
callTableTitle这里是自写的函数,用于创建表格标志
callbeginTr这里是创建表格tr标志

fori=0tors.fields.Count-1遍历纪录集字段
callAddCol(rs(i).name)输入字段名
Next

callendTr

whilenotrs.eof轮回纪录集内容,并输入
callbeginTr

fori=0tors.fields.Count-1
callAddRow(ASPEncode(rs(i).value))
Next
callendTr
endID=rs("主动编号")这里保留每次输入的主动编号值
rs.MoveNext
Wend
callTableBottom到此为止,就复杂的将纪录集内容全体输入
这里输入翻页标志,vbaIIF是自写函数
原型为functionvbaIIF(a,b,c)
ifathen
vbaIIF=b
else
vbaIIF=c
endif
endfunction

上一页的完成是经由过程剧本挪用扫瞄器的功效history.back(1)完成,那末回页时其实不必要在服务器端从头天生数据,速率不必思索了。
在首页的时分,上一页的链策应该是有效的,经由过程vbaIIF(isBeginPage,"disabled","")完成,假如为首页,那末在标志中到场disabled属性,假如不是首页,则到场history.back(1);剧本指令,用于回退扫瞄页。
下一页是传送Page参数和endID参数,Page设置为next暗示为下一页的举措,endID暗示以后纪录集的开端编号,下页将由此分页。

response.Write("〈ahref=""#""onclick=""javascript:"&vbaIIF(isBeginPage,"","history.back(1);")&""""&vbaIIF(isBeginPage,"disabled","")&"〉上一页〈/a〉|〈ahref=""TypeOptions.asp?flbm="&request("flbm")&"&Page=next&endID="&endID&"""〉下一页〈/a〉")
else
这里经由过程判别纪录集是不是为空来办理到开端页还能够持续翻页的成绩
ifnotisBeginPagethen
判别是不是为空纪录,而且不是肇端页,那末天生回退页面的剧本,效果就是进进该页后将主动前往到上页。
response.Write"〈Scriptlanguage=javascript〉"&vbCrlf
Response.Write"history.back(1);"&vbCrlf
Response.Write"〈/script〉"
Response.End
else假如是肇端页纪录就为空,则提醒无内容
Response.Write"〈fontcolor=blue〉该种别下无内容〈/fon</p>ASP在国内异常流行,因为国内大多使用的是盗版的Windows和盗版的SQLServer,而ASP+COM+SQLServer实际上也是一种不错的搭配,其性能也不输于PHP+MYSQL,特别是Windows系统和SQLServer都有图形界面,比APACHE和MYSQL易于维护,因此对于不重视知识产权的国家来说也是一种不错的选择。

山那边是海 发表于 2015-1-20 09:58:48

完全不知道到底自己学的是什么。最后,除了教程里面说的几个例子,还是什么都不会。

深爱那片海 发表于 2015-1-31 22:40:03

在平时的学习过程中要注意现学现用,注重运用,在掌握了一定的基础知识后,我们可以尝试做一些网页,也许在开始的时候我们可能会遇到很多问题,比如说如何很好的构建基本框架。

小女巫 发表于 2015-2-7 01:05:44

Application:这个存储服务端的数据,如果不清除,会直到web应用程序结束才清除(例如重启站点)

蒙在股里 发表于 2015-2-19 05:44:37

掌握asp的特性而且一定要知道为什么。

活着的死人 发表于 2015-3-6 13:17:46

代码逻辑混乱,难于管理:由于ASP是脚本语言混合html编程,所以你很难看清代码的逻辑关系,并且随着程序的复杂性增加,使得代码的管理十分困难,甚至超出一个程序员所能达到的管理能力,从而造成出错或这样那样的问题。

爱飞 发表于 2015-3-13 01:08:34

那么,ASP.Net有哪些改进呢?

分手快乐 发表于 2015-3-20 08:42:40

以上是语言本身的弱点,在功能方面ASP同样存在问题,第一是功能太弱,一些底层操作只能通过组件来完成,在这点上是远远比不上PHP/JSP,其次就是缺乏完善的纠错/调试功能,这点上ASP/PHP/JSP差不多。
页: [1]
查看完整版本: ASP网站制作之数据分页办法新思绪,速率十分快