搜索
首页专题Accessaccess数据库分页方法介绍

access数据库分页方法介绍

Jan 22, 2021 am 10:50 AM
access数据库

access数据库分页方法介绍

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

(学习视频分享:编程入门

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

1、方法

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

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、原理

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

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

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

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

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

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

3、举例

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

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方法

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

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选择出来

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

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

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

三、分页查询效率

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

相关推荐:access数据库教程

以上是access数据库分页方法介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:csdn。如有侵权,请联系admin@php.cn删除

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具