由于数据库记录比较多,所以需要对查询结果进行分页显示。下面是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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

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

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

SublimeText3汉化版
中文版,非常好用

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具