加入收藏 | 设为首页 | 会员中心 | 我要投稿 哈尔滨站长网 (https://www.0451zz.cn/)- 人体识别、图像分析、开发者工具、基础存储、物联安全!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP 分页代码与分页原理解析

发布时间:2022-07-22 09:14:34 所属栏目:PHP教程 来源:互联网
导读:本文章来给各位php入门者提供在php与mysql实现分页代码与原理,在mysql中支持limit 0,1这样就是查询0,1条记录了,有了它在php中分页就简单快速多了。 所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:1,每页多少条
  本文章来给各位php入门者提供在php与mysql实现分页代码与原理,在mysql中支持limit 0,1这样就是查询0,1条记录了,有了它在php中分页就简单快速多了。
 
  所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:1,每页多少条记录($PageSize)2,当前是第几页($CurrentPageID).
 
  现在只要再给我一个结果集,我就可以显示某段特定的结果出来,至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
 
  以MySQL数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率,代码如下:
 
  select * from table limit 0,10 // 前10条记录
  select * from table limit 10,10 // 第11至20条记录
  select * from table limit 20,10 // 第21至30条记录
  ……
  这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板,代码如下:
 
  select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
 
  拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事,搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了,以下我将用具体代码加以说明.
 
  <html>
  <head>
  <title>
  ShowData
  </title>
  </head>
  <body>
  <h2>ShowData</h2>
  <?php
      //连接数据库     
      $page = 1;
          $db = mysql_connect('127.0.0.1','root','toor');
          mysql_select_db('test',$db);
       
          $pagesize = 3;    //每页显示到数量
       
      //计算一共有多少记录,用于计算页数
      $rs = mysql_query("select count(*) from info",$db);
      $row = @mysql_fetch_array($rs);
      $numrows = $row[0];
      //计算页数
      $pages = intval($numrows / $pagesize);
      if ($numrows % $pagesize)
      {
          $pages++;
      }
      //设置页数
      if (isset($_GET['page']))
      {     
          $page = intval($_GET['page']);
      }
      else
      {
          $page = 1;        //其他情况,都指向第一页
      }
       
      //计算记录的偏移量
      $offset = $pagesize * ($page - 1);
      //读取指定记录
      $rs = mysql_query("select * from info order by id limit $offset,$pagesize",$db);
      //把数据用表格显示出来
      if ($row = @mysql_fetch_array($rs))
      {
          $i = 0;
          ?>
          <table border='0' width='80%'>
          <tr>
          <td width='50%'>
          <p align='center'>ID</td>
          <td width='50%'>
          <p align='center'>DOC</td>
          </tr>
          <?php
              do{
                  $i++;
          ?>
          <tr align='center'>
          <td width='50%'><?=$row['id']?></td>
          <td width='50%'><?=$row['doc']?></td>
          </tr>
          <?php
              }
              //循环显示数据
              while ($row = mysql_fetch_array($rs));
              echo "</table>";
      }
      echo "<div align='center'> 共".$pages."页(".$page."/".$pages.")";
      for ($i = 1;$i < $page;$i++)
      {
          echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>";
      }
      echo "[".$page."]";
      for ($i = $page + 1;$i <= $pages;$i++)
      {
          echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>";
      }
      echo "</div>";
      ?>
  </body>
  </html>
  总结:分页就根据用户点击连接,然后由于php获取page值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。

(编辑:哈尔滨站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读