数据分页方法的新思想非常快。
一个Web应用程序的建立、标签浏览必不可少的;这个问题一直是最常见的问题,也就解决了,哪像分页算法的ASP程序有很多,如ADO为对象的使用根据这些性质,记录统计总页数,然后跳到记录集的输出;写一个存储过程实现数据分页,它有它的优点和缺点,很快的分页算法以下我一个项目的实际应用;
关键点:SQL(用顶部和自动编号实现)
页面脚本(浏览器回滚功能)
环境科学uff1a
IIS访问
表结构:
创建表内容表(
自动编号标识(int,1,1)不为空,
分类编码varchar(20)空,
标题varchar(255)空,
内容varchar(4000)空,
时间日期无效,
)
实现原理:
表中设置自动编号字段,这个字段的特性是产生整形手术是不重复的,包括已删除的记录后,现场仍然是水(注:通常在系统建设中,外地很少,因为数量不自由的管理,但在这里它是保持在第码数略)。
Paging:
然后,第一步是要查询一个数据页;如果有100条记录,20条记录根据页面,然后页面数通常是分页算法=总记录数的寻呼控制部{ }以总页数,这种方法会导致一个大的记录必须提供所有记录集;因此,提出了利用存储过程分页算法,前者是ASP脚本来生成一个大的记录集,所以速度是缓慢的,后者是不必要的,虽然我经常存储过程编写,但根据我的想法会发现写完全冗余的存储过程。
在SQL中,很多刚接触的朋友都知道,最关键的作用;例如:选择前1 *表,从而实现从表1表只返回一个记录集分页优化,避免由最高记录可以完全控制现在的终极目标;查询表应选择20自动编号,标题,内容,内容从时刻表。
但是现在有一个问题,就是如何定位顶部,不能给我们一个自动定位输出页面,这个设计要到哪里,根据特定的条件输出正确的内容;注意:按排名顺序记录是非常重要的,这就决定了这个算法的成败;
这里是一个演示说明,反序,如Web软件更新,最新更新的放在前面,这是颠倒的方式。
好,让我们看看实际的代码,首先确定它是否是起始页。
昏暗的如何,我,它,isbeginpage
const cnt_pagesize = 20定义每个页面记录大小
通过检查浏览器传递的页面参数的值,确定是否是进入下一页的操作。
isbeginpage =空(请求(页))或要求(页)= 或要求(页下一个)
这是分页的核心。
如果isbeginpage然后如果它的起始页
查询=列表分类编码参数flbm等于记录,反过来,只列出前cnt_pagesize笔(cnt_pagesize是定义的常量,如20)
如何为选择顶部的cnt_pagesize 自动编号,标题,内容,时间从内容表,分类编码= 修剪(SQLEncode(请求(flbm ))),顺序自动编号。
否则,如果不是起始页
如果请求(页)=下,那么这里写的是为了增强代码的性能,如果参数是下一个,则页面内容被删除。
查询=列表分类编码参数flbm等于记录和小于号它(它是自动参数),和相反的顺序,只列出前cnt_pagesize笔(cnt_pagesize是定义的常量,如20)
如何为选择顶部的cnt_pagesize 自动编号,标题,内容,时间从内容表,分类编码= 修剪(SQLEncode(请求(flbm ))),自动电话号码。
最后如果
打开数据连接以执行SQL并设置一个记录集
集=美国有线电视新闻网执行(如何)。
如果不是,那么在这里写EOF判断EOF可以没有,但这里有其特殊的意义。
电话tabletitle '在这里是一个自写函数用于创建表的标记
电话begintr '这里是表tr标签的建立
我= 0 rs.fields.count-1的遍历记录集字段
电话addcol(RS(我)。名称)的输出字段名
下一个
电话endtr
而not rs.eof的循环记录集的内容,并输出
电话begintr
我rs.fields.count-1 = 0
叫addRow(aspencode(RS(我)。值))
下一个
电话endtr
它= RS(自动编号)这里保存自动编号的值为每个输出
移到下一项
走
电话tablebottom至今,只是输出的记录集的内容
从网页的标签,vbaiif是自写函数
原型系统的功能vbaiif(A,B,C)
如果再
vbaiif = B
其他的
vbaiif = C
最后如果
端功能
上一页的实现是通过脚本调用浏览器的功能history.back实施(1)。然后,页面不需要在服务器端重新生成数据,因此不考虑速度。
在首页,一个页面的链接应该是无效的,由vbaiif(isbeginpage,残疾人
下一页是通过页面的参数和它的参数。页面设置为下一页动作。它表示当前记录集的末尾数,和下一个页面将分页。
响应。写(# href = onclick= Javascript:(vbaiif isbeginpage,的历史。回来,(1);(vbaiif)isbeginpage,残疾人
其他的
这里的问题是要确定记录集为空解决结束页可以分页。
如果不isbeginpage然后
判断是否为空,而不是起始页,则生成返回页的脚本,其效果是在页面输入后自动返回到顶部页。
响应。写脚本语言Javascriptvbcrlf
响应。写history.back(1);vbcrlf
响应。
反应结束
否则,如果起始页记录为空,则提示没有内容。
在无内容类别下的响应写字体颜色=蓝色。
最后如果
最后如果
摘要:通过前端脚本、sql查询技术,高性能的分页程序简单快捷。
一种较好的实时数据分页算法有望由同行提出。
注:因为论坛限制了HTML字符,所以关键符号使用了中国资本。