PHP程序员小白到大牛集训(12期免息)
作者信息
视频教程分类
推荐视频教程
  • php程序员小白到大牛三个月集训php程序员小白到大牛三个月集训
  • Laravel 9 学习正当时—保姆级教程,想学不会都难!Laravel 9 学习正当时—保姆级教程,想学不会都难!
  • 千万级数据并发解决方案(理论+实战)千万级数据并发解决方案(理论+实战)
  • Laravel基础与实战(模块化)Laravel基础与实战(模块化)
  • 首页 >专题 >Access > 正文

    access数据库分页方法介绍

    转载2021-01-22 10:50:442454 关注公众号:每天精选资源文章推送

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

    20期PHP线上班

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

  • 相关标签:access 数据库
  • 推荐:PHP从基础到实战教程视频

    相关文章

    相关视频


    专题推荐