中国站长下载-为中国站长提供最好最全的建站资源! 首 页发布资源有事留言繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:中国站长下载 -> 文章中心 -> 网页编程 -> PHP编程 -> 文章内容  虚拟主机 域名注册 退出登录 用户管理
栏目导航
· ASP编程 · .NET编程
· PHP编程 · JSP编程
· CGI 专区
热门文章
· sndvol32 - sndvol3...
· [组图] FLASH:《大话李白》...
· 个人网站到底能赚多...
· [图文] Rundll.exe是病毒吗...
· [组图] Flash:制作MV
· 价值12万元的网站SE...
· 网站创业者,你需要...
· 一个成功的网站设计...
· [图文] FLASH:韩国导航条解...
· 中国网站的赚钱模式...
相关文章
· PHP应用分页显示制作...
· PHP应用分页显示制作...
· PHP应用分页显示制作...
· PHP应用分页显示制作...
· [组图] ASP.NET 1.1 新特征...
· [图文] 在Apache上调试ASP....
· [图文] 在Apache上调试ASP....
· 在Apache上调试ASP....
· 从ASP.NET 1.1升级到...
· 12popup - 12popup....
PHP应用分页显示制作详细讲解 (1)
作者:不详  来源:不详  发布时间:2006-8-14 10:21:31  发布人:chinazhan

 减小字体 增大字体

     1、前言
  
    分页显示是一种非常常见的浏览和显示大量数据的方法,属于Web编程中最常处理的事件之一。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解,力求让看完这篇文章的朋友在看完以后对于分页显示的原理和实现方法有所了解。本文适合初学者阅读,所有示例代码均使用PHP编写。
  
    2、原理
  
    所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:
  
     每页多少条记录($PageSize)?
     当前是第几页($CurrentPageID)?
  
    现在只要再给我一个结果集,我就可以显示某段特定的结果出来。
  
    至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
  
    以MySQL数据库为例,如果要从表内截取某段内容,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从数据库内获取数据并显示了。以下我将用具体代码加以说明。
  
    3、简单代码
  
    请详细阅读以下代码,自己调试运行一次,最好把它修改一次,加上自己的功能,比如搜索等等。
  
  <?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 < $page_size ){ $page_count = 1; } //如果总数据量小于$PageSize,那么只有一页
    if( $amount % $page_size ){ //取总数据量除以每页数的余数
     $page_count = (int)($amount / $page_size) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
    }else{
     $page_count = $amount / $page_size; //如果没有余数,则页数等于总数据量除以每页数的结果
    }
   }
   else{
    $page_count = 0;
   }
  
   // 翻页链接
   $page_string = '';
   if( $page == 1 ){
    $page_string .= '第一页|上一页|';
   }
   else{
    $page_string .= '<a href=?page=1>第一页</a>|<a href=?page='.($page-1).'>上一页</a>|';
   }
   if( ($page == $page_count) || ($page_count == 0) ){
    $page_string .= '下一页|尾页';
   }
   else{
    $page_string .= '<a href=?page='.($page+1).'>下一页</a>|<a href=?page='.$page_count.'>尾页</a>';
   }
   // 获取数据,以二维数组格式返回结果
   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就可以很简单的用得到的二维数组来显示结果
  ?>
  
  
  
    做人要厚道,请注明转自chinazhan中国站长(www.ChinaZhan.com)。

 
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
中国站长下载
中国站长下载

本页只接受PR>=4 IT类站点连接,申请连接,谢谢您们的支持!希望我们的下载站能够真正帮到中国的站长们!
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图
Copyright © 2005-2006 ChinaZhan.Net. All Rights Reserved .