在网站开发中,如果列表页内容过多,一般会设置分页功能。 今天爱站科技频道小编就为大家带来PHP实现分页显示的操作方法。 下面就跟着小编的步骤一起来学习吧!
所谓分页显示,就是将数据库中的结果集人为地分成几部分进行显示。 这里需要两个初始参数:
每页有多少条记录 ($PageSize)?
当前页面是什么($CurrentPageID)?
现在只要给我另一个结果集,我就可以显示特定的结果。
至于其他参数,如:上一页($PReviousPageID)、下一页($NextPageID)、总页数($numPages)等,可以根据之前的知识获取。
以MySQL数据库为例php实现分页,如果想从表中截取某条内容,可以使用sql语句:select * from table limit offset, rows。 看下面这组sql语句,尝试找出其中的规律。
前10条记录:select * from table limit 0,10
记录11到20:select * from table limit 10,10
记录21到30:select * from table limit 20,10
...
这组sql语句好像是$PageSize=10时从表中每页取数据的sql语句。 我们可以总结这样一个模板:
select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
使用这个模板替换对应的值,与上面这组sql语句进行比较,看看是否是这样。 解决了最重要的如何获取数据的问题后,剩下的就是传递参数,构造合适的sql语句,然后使用php从数据库获取数据并显示出来。 下面我用具体代码来说明。
简单的代码实现
请详细阅读下面的代码,自己调试运行一下,最好改一次,添加自己的功能,比如搜索等。
// 建立数据库连接 $link = mysql_connect("localhost", "mysql_user", "mysql_passWord") or die("Could not connect: " . mysql_error()); // 获取当前页数 if( isset($_GET['page']) ){ $page = intval( $_GET['page'] ); } else{ $page = 1; } // 每页数量 $PageSize = 10; // 获取总数据量 $sql = "select count(*) as amount from table"; $result = mysql_query($sql); $row = mysql_fetch_row($result); $amount = $row['amount']; // 记算总共有多少页 if( $amount ){ if( $amount 上一页|'; } if( ($page == $page_count) || ($page_count == 0) ){ $page_string .= '下一页|尾页'; } else{ $page_string .= '.($page+1).'>下一页|.$page_count.'>尾页'; } // 获取数据,以二维数组格式返回结果 if( $amount ){ $sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size"; $result = mysql_query($sql); while ( $row = mysql_fetch_row($result) ){ $rowset[] = $row; } }else{ $rowset = array(); } // 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果 ?>
以上就是爱站科技频道小编给大家带来的php实现分页显示的操作方法。 其实只要你不是太辛苦、太麻烦php实现分页,这绝对对我们的学习有好处。
原文链接:
如有疑问请联系原作者