php实现分页显示的操作方法

2023-08-26 0 3,810 百度已收录

在网站开发中,如果列表页内容过多,一般会设置分页功能。 今天爱站科技频道小编就为大家带来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实现分页,这绝对对我们的学习有好处。

原文链接:

如有疑问请联系原作者

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悟空资源网 php php实现分页显示的操作方法 https://www.wkzy.net/game/160780.html

常见问题

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务