欧非资源网:安全、免费、专业放心的资源下载站! 最新软件|软件分类

您的位置:欧非资源网 > 其他专区 > Access > access数据库分页方法介绍

access数据库分页方法介绍

时间:2021-01-24 20:46作者:admin来源:未知人气:568我要评论(0)

access数据库分页方法介绍

由于数据库记录比较多,所以需要对查询结果进行分页显示。下面是access数据库的两种分页方法。

一、Access查询结果分页方法一

1、方法

设每页记录数为CntPerPage,要获得第Page页的查询结果,用以下SQL语句。

1

2

3

4

5

SELECT * FROM (

SELECT TOP CntPerPage * FROM(

SELECT TOP Page*CntPerPage * FROM TableName WHERE Query_Conditionm ORDER BY OrderField

) ORDER BY OrderField DESC

) ORDER BY OrderField

其中TableName为表名,Query_Condition为查询条件,OrderField为用来排序的字段名

2、原理

嵌套使用三步查询:
第一步查询:将当前页及之前所有页的记录查询出来,并按排序字段降序排列

1

SELECT TOP Page*CntPerPage * FROM TableName WHERE Query_Conditionm ORDER BY OrderField

第二步查询:将刚才查询出来的记录(已降序排列)的前CntPerPage个记录查询出来(保持降序排列),这些就是第Page页的所有记录

1

SELECT TOP CntPerPage * FROM( 第一步查询结果 ) ORDER BY OrderField DESC

第三步查询:上一步查询实际已经把第Page页的记录全部查询出来了,只不过是降序排列的,这第三步只是把刚获得的这些数据变成正序排列。如果对顺序不要求,或者程序中有其它的数据排序处理,那么这一步就可以省略了。

1

SELECT * FROM ( 第二步查询结果 ) ORDER BY OrderField

3、举例

一个Student表,要查询年龄age小于20岁的所有记录,按姓名name排序,每页记录数为100,要获得第5页的查询结果,则用以下SQL语句。

1

SELECT * FROM (SELECT TOP 100 * FROM( SELECT TOP 500 * FROM Student  WHERE age<20 ORDER BY name ) ORDER BY name DESC) ORDER BY name

二、网上常用的NOT IN方法

在网上搜索分页方法时,这是最常见到的一种方法。
方法:

1

2

3

SELECT TOP CntPerPage * FROM TableName WHERE Query_Conditionm AND id NOT IN (

SELECT TOP (Page-1)*CntPerPage id FROM TableName WHERE Query_Conditionm ORDER BY id

) ORDER BY id

原理:
两步查询:
第一步:把本页之前的所有符合条件的记录id选择出来

1

SELECT TOP (Page-1)*CntPerPage id FROM TableName WHERE Query_Conditionm ORDER BY id

第二步:加入查询条件“id不在刚才选择出来的那些id查询结果里”,取前CntPerPage个记录,这样,查询结果就恰好过滤了前Page-1页的所有数据,之后就选择了第Page页的所有记录。

1

SELECT TOP CntPerPage * FROM TableName WHERE Query_Conditionm AND id NOT IN (第一步查询结果) ORDER BY id

三、分页查询效率

实际测试两种方法的效率差不多,但个人认为第二种方法里的NOT IN这类判断的效率应该不会太高,所以觉得如果记录量比较庞大时应该第一种方法更高效些。

相关阅读 ​access怎么做点击选择学历的效果​access怎么取消冻结字段​access怎么冻结字段​access怎么删除子数据表​access怎么在表格中插入子数据表​access设置快速访问栏在功能区下方显示​access设置快速访问栏在功能区上方显示​access怎么将设计视图加到快速访问栏​access怎么将导出Excel表格加到快速访问栏​access怎么将数据表视图加到快速访问栏

文章评论
发表评论

热门文章 Microsoft Office Access 2019 官方版激活版 免费下载如何设计一个简单的Access登录窗体Access创建数据库实现图解教程access怎么求平均成绩

最新文章 ​access怎么做点击选择学历的效果​access怎么取消冻结字段 ​access怎么冻结字段​access怎么删除子数据表​access怎么在表格中插入子数据表​access设置快速访问栏在功能区下方显示

人气排行 Microsoft Office Access 2019 官方版激活版 免费下载如何设计一个简单的Access登录窗体Access创建数据库实现图解教程access怎么求平均成绩怎么在Access报表的页面页脚区添加一个计算控件Access 2007、2010、2016三个版本的使用心得Access查询标准(条件)详解电脑没有access怎么办? access文件打不开怎么办?

盖楼回复X

(您的评论需要经过审核才能显示)