首页 > 开发 > PHP > 正文

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

2024-05-04 23:06:45
字体:
来源:转载
供稿:网友

本文章来给各位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语句,尝试一下发现其中的规率,代码如下:

  1. select * from table limit 0,10 // 前10条记录 
  2. select * from table limit 10,10 // 第11至20条记录 
  3. select * from table limit 20,10 // 第21至30条记录 
  4. …… 

这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板,代码如下:

select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize

拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事,搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了,以下我将用具体代码加以说明.

  1. <html> 
  2. <head> 
  3. <title> 
  4. ShowData 
  5. </title> 
  6. </head> 
  7. <body> 
  8. <h2>ShowData</h2> 
  9. <?php 
  10.     //连接数据库     
  11.     $page = 1; 
  12.         $db = mysql_connect('127.0.0.1','root','toor'); 
  13.         mysql_select_db('test',$db); 
  14.      
  15.         $pagesize = 3;    //每页显示到数量 
  16.      
  17.     //计算一共有多少记录,用于计算页数 
  18.     $rs = mysql_query("select count(*) from info",$db); 
  19.     $row = @mysql_fetch_array($rs); 
  20.     $numrows = $row[0]; 
  21.     //计算页数 
  22.     $pages = intval($numrows / $pagesize); 
  23.     if ($numrows % $pagesize
  24.     { 
  25.         $pages++; 
  26.     } 
  27.     //设置页数 
  28.     if (isset($_GET['page'])) 
  29.     {     
  30.         $page = intval($_GET['page']); 
  31.     } 
  32.     else 
  33.     { 
  34.         $page = 1;        //其他情况,都指向第一页 
  35.     } 
  36.      
  37.     //计算记录的偏移量 
  38.     $offset = $pagesize * ($page - 1); 
  39.     //读取指定记录 
  40.     $rs = mysql_query("select * from info order by id limit $offset,$pagesize",$db); 
  41.     //把数据用表格显示出来 
  42.     if ($row = @mysql_fetch_array($rs)) 
  43.     { 
  44.         $i = 0; 
  45.         ?> 
  46.         <table border='0' width='80%'
  47.         <tr> 
  48.         <td width='50%'
  49.         <p align='center'>ID</td> 
  50.         <td width='50%'
  51.         <p align='center'>DOC</td> 
  52.         </tr> 
  53.         <?php 
  54.             do
  55.                 $i++; 
  56.         ?> 
  57.         <tr align='center'
  58.         <td width='50%'><?=$row['id']?></td> 
  59.         <td width='50%'><?=$row['doc']?></td> 
  60.         </tr> 
  61.         <?php 
  62.             } 
  63.             //循环显示数据 
  64.             while ($row = mysql_fetch_array($rs)); 
  65.             echo "</table>"
  66.     } 
  67.     echo "<div align='center'> 共".$pages."页(".$page."/".$pages.")"
  68.     for ($i = 1;$i < $page;$i++) 
  69.     { 
  70.         echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>"
  71.     } 
  72.     echo "[".$page."]"
  73.     for ($i = $page + 1;$i <= $pages;$i++) 
  74.     { 
  75.         echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>"
  76.     } 
  77.     echo "</div>"
  78.     ?> 
  79. </body> 
  80. </html> 

总结:分页就根据用户点击连接,然后由于php获取page值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表