| 
       本文章来给各位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  
 
	- select * from table limit 10,10  
 
	- select * from table limit 20,10  
 
	- …… 
 
	 
 
这一组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值再经过一系列算法得出当前多少页面,然后取多少要就显示出你要查看的记录了。 
      
      (责任编辑:admin) |