搜索
首页后端开发PHP问题php怎么实现查询分页显示功能

在进行数据库查询时,在一些情况下,我们需要将结果按照一定的规则进行分页显示。比如,当我们想让客户端的每一页只展示少量的数据时,在实现页面效果的同时,我们需要使用查询分页显示功能。本文将聚焦PHP开发语言的查询分页功能,通过实例介绍它的实现原理和步骤。

查询分页显示的实现原理

查询分页显示的实现原理很简单,我们可以把查询到的所有数据按照一定的规则进行排序,然后通过限制每页数据显示的数量,将查询结果进行分页显示。我们可以通过算法计算出需要显示的记录从数据库中的哪一条开始,到哪一条为止。

主要步骤如下:

1.计算总记录数:通常情况下,我们需要查询出数据库中所有的记录,也即总记录数。

2.计算总页数:通过总记录数和每页显示记录数的比对,可以算出总页数。如果总页数除以每页显示记录数得到的余数不为零,则总页数需要加一。

3.查询当前页的数据:计算出当前页的需要查询的记录的开始和结束位置,然后使用SQL语句查询数据。不过这里的SQL语句需要进行一些改造,不能仅是简单地查询全部记录,而是需要增加查询条件和限制查询结果的数量。

4.分页显示:通过页面分页组件,可以方便的进行分页显示。通常情况下,分页组件会将总记录数、当前页数、总页数等信息进行展示。同时,还可以通过点击不同的页数来实现不同页的数据查询和显示。

代码实现

为了实现这些步骤,我们需要使用一个PHP函数来进行分页的处理。通常情况下,这个函数需要接收一些必要的参数,例如总记录数、每页显示记录数、当前页数等。以Mysql数据库为例,下面是常见的一个PHP分页函数:

function get_data($page_size,$sql,$conn){
  global $start;
  if(!$page_size) $page_size = 10;
  $page = $_GET['page']?$_GET['page']:1;
  $start=($page-1)*$page_size; //这里是高亮应用,可以注释掉
  $sql_limit = $sql." limit $start,$page_size"; //组合成一条完整的sql语句
  $result = mysql_query($sql_limit,$conn);
  while($row = mysql_fetch_array($result)){
      $data[] = $row;
  }
  return $data;
}

上面的函数主要实现了根据每页展示数、总记录数以及当前页数来查询并返回需要展示的数据的功能。接下来,我们将和您一起实现一个包含分页功能的PHP查询页面。

首先,我们需要构造一个数据源,这里我们使用一个简单的students表 (其字段包括id、name、gender、age):

CREATE TABLE `students` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(32) NOT NULL,
  `gender` enum('male','female') NOT NULL,
  `age` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

然后将数据插入到students表中:

INSERT INTO `students` (`id`, `name`, `gender`, `age`) VALUES
(1, 'Tom', 'male', 19),
(2, 'Lucy', 'female', 20),
(3, 'Lily', 'female', 18),
(4, 'Kevin', 'male', 19),
(5, 'Steve', 'male', 21),
(6, 'Tony', 'male', 20),
(7, 'Henry', 'male', 20),
(8, 'Alex', 'male', 18),
(9, 'Sara', 'female', 21),
(10, 'Lily', 'female', 20),
(11, 'Michael', 'male', 19),
(12, 'Paul', 'male', 22),
(13, 'Elena', 'female', 18),
(14, 'Jack', 'male', 21),
(15, 'Bob', 'male', 19),
(16, 'Sophie', 'female', 20),
(17, 'Lisa', 'female', 21),
(18, 'Lucas', 'male', 19),
(19, 'Laura', 'female', 18),
(20, 'John', 'male', 20);

我们需要实现以下3个文件:

  1. index.php,该文件是分页过程的实际载体,需要将处理分页过程的函数进行调用,并根据函数的返回值进行数据输出。
  2. page.class.php,这个类主要实现了分页的功能,包括在定义分页对象时需要传入的参数和计算分页相关的核心功能。
  3. db.class.php,这个类主要是用来封装和管理与数据库相关的操作。

内容如下:

index.php:

nbsp;html>


<meta>
<title>PHP分页查询 - 测试页面</title>



    <?php         include("db.class.php"); //加载数据库操作类
        include("page.class.php"); //加载分页类
        $page = new page(); //初始化分页类
        $db = new db("localhost","root","","test","$conn"); //连接数据库
        $count = $db->query("SELECT count(*) FROM students"); //查询总记录数
        $page->get_page($count,10); //调用分页方法,传入总记录数和每页显示记录数
        $genders = array("male"=>"男性","female"=>"女性");
        $results = $db->query("SELECT * FROM students {$page->limit}"); //获取当前页数据
        foreach($results as $row){ //遍历数据并渲染页面
            $gender = $genders[$row["gender"]];
            echo $row["id"]." ".$row["name"]." ".$gender." ".$row["age"]."<br>";
        }
        echo $page->display_pages(); //渲染分页组件
    ?>

page.class.php:

<?php /**
 * PHP分页类
 */
class page {
    public $total = 0; //总记录数
    public $page_size = 10; //每页显示的记录数
    public $cur_page = 1; //当前页数
    public $cur_offset = 0; //当前偏移量
    public $total_page = 0; //总页数
    public $limit = "";//分页查询限制语句

    public function __construct(){
        $this->cur_page = isset($_GET['page'])? intval($_GET['page']):1; //获取当前页,默认为第一页
    }

    /**
     * 生成分页显示代码
     */
    public function display_pages(){
        $page_list = "";
        $url_s = $_SERVER['REQUEST_URI'] . (strpos($_SERVER['REQUEST_URI'], '?')?'':"?")."&page=";
        //上一页
        if($this->cur_page>1){
            $page_list.="<a>首页</a>";
            $page_list.="<a>cur_page-1)."'>上一页</a>";
        }
        //数字页码
        for($i=1;$itotal_page;$i++){
            if($i==$this->cur_page){
                $page_list.="<span>".$i."</span>";
            } else {
                $page_list.="<a>$i</a>";
            }
        }
        //下一页
        if($this->cur_pagetotal_page){
            $page_list.="<a>cur_page+1)."'>下一页</a>";
            $page_list.="<a>total_page}'>尾页</a>";
        }
        $page_list.="共{$this->total_page}页,";
        $page_list.="
";         return $page_list;     }     /**      * 计算分页相关参数      * @param int $count 总记录数      * @param int $page_size 每页显示记录数      */     public function get_page($count,$page_size){         $this->total = intval($count); //总记录数         $this->page_size = intval($page_size); //每页显示多少条         $this->total_page = ceil($this->total/$this->page_size); //总页数         $this->cur_page = min($this->total_page,max(1,intval($this->cur_page))); //当前页码         $this->cur_offset = ($this->cur_page-1)*$this->page_size; //当前查询的偏移量         $this->limit = " LIMIT {$this->cur_offset},{$this->page_size}"; //查询限制语句     } }

db.class.php:

<?php /**
 * 数据库操作类
 */
class db {
    private $conn;

    public function __construct($db_host,$db_user,$db_pass,$db_name){
        $this->conn = new mysqli($db_host,$db_user,$db_pass,$db_name);
        if(mysqli_connect_errno()) {
            exit("连接数据库失败!");
        }
        $this->conn->query("SET NAMES 'utf8'");
    }

    /**
     * mysql查询
     */
    public function query($sql){
        $results = array();
        $query = $this->conn->query($sql);
        if(!$query) return false;
        while($row = $query->fetch_array(MYSQLI_ASSOC)){
            $results[] = $row;
        }
        return $results;
    }

    public function __destruct(){
        $this->conn->close();
    }
}

分页代码的执行步骤如下:

  1. 首先,我们需要调用db.class.php,建立到数据库的连接;
  2. 通过query()方法查询总的记录条数;
  3. 调用get_page()方法,预先计算需要展示的页面的总数,并定义限制查询语句中限制数量和查询的开始点的值limit;
  4. 通过使用渲染函数display_pages()进行分页显示组件的渲染。

运行index.php文件之后,我们会看到一个分页展示的页面,它会按照我们预期的方式进行每页展示数量、页码列表和展示结果的准确性。

以上是php怎么实现查询分页显示功能的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
酸与基本数据库:差异和何时使用。酸与基本数据库:差异和何时使用。Mar 26, 2025 pm 04:19 PM

本文比较了酸和基本数据库模型,详细介绍了它们的特征和适当的用例。酸优先确定数据完整性和一致性,适合财务和电子商务应用程序,而基础则侧重于可用性和

PHP安全文件上传:防止与文件相关的漏洞。PHP安全文件上传:防止与文件相关的漏洞。Mar 26, 2025 pm 04:18 PM

本文讨论了确保PHP文件上传的确保,以防止诸如代码注入之类的漏洞。它专注于文件类型验证,安全存储和错误处理以增强应用程序安全性。

PHP输入验证:最佳实践。PHP输入验证:最佳实践。Mar 26, 2025 pm 04:17 PM

文章讨论了PHP输入验证以增强安全性的最佳实践,重点是使用内置功能,白名单方法和服务器端验证等技术。

PHP API率限制:实施策略。PHP API率限制:实施策略。Mar 26, 2025 pm 04:16 PM

本文讨论了在PHP中实施API速率限制的策略,包括诸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之类的库。它还涵盖监视,动态调整速率限制和手

php密码哈希:password_hash和password_verify。php密码哈希:password_hash和password_verify。Mar 26, 2025 pm 04:15 PM

本文讨论了使用password_hash和pyspasswify在PHP中使用密码的好处。主要论点是,这些功能通过自动盐,强大的哈希算法和SECH来增强密码保护

OWASP前10 php:描述并减轻常见漏洞。OWASP前10 php:描述并减轻常见漏洞。Mar 26, 2025 pm 04:13 PM

本文讨论了OWASP在PHP和缓解策略中的十大漏洞。关键问题包括注射,验证损坏和XSS,并提供用于监视和保护PHP应用程序的推荐工具。

PHP XSS预防:如何预防XSS。PHP XSS预防:如何预防XSS。Mar 26, 2025 pm 04:12 PM

本文讨论了防止PHP中XSS攻击的策略,专注于输入消毒,输出编码以及使用安全增强的库和框架。

PHP接口与抽象类:何时使用。PHP接口与抽象类:何时使用。Mar 26, 2025 pm 04:11 PM

本文讨论了PHP中接口和抽象类的使用,重点是何时使用。界面定义了无实施的合同,适用于无关类和多重继承。摘要类提供常见功能

See all articles

热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尊渡假赌尊渡假赌尊渡假赌
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平台上运行。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境