好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

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

本文章来给各位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值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。

查看更多关于PHP 分页代码与分页原理解析 - php分页的详细内容...

  阅读:72次