| 网站镜像:电信 网通 | 加入收藏 | 设为首页

PHP中记录分页显示实例(转)

  • 在PHP网络数据库编程时,不可避免的要考虑到数据库记录结果的显示问题,为了呈现美观页面并加快页面的载入速度,就需要对数据库记录进行分页显示。

    现把与PHP完美结合的MySQL数据库记录的分页显示实例拿出来与大家共享。

    MySQL数据库为XinXiKu,数据表为joke。其定义SQL语句如下:

    CREATE TABLE joke (
    id int(5) NOT NULL auto_increment,
    biaoti varchar(40) NOT NULL,
    neirong text NOT NULL,
    PRIMARY KEY (id)
    );
    字段说明:

    id    :记录号,自动递增且为主键

    biaoti  :标题

    neirong :内容

    <html>
    <head>
    <title>分页显示的实现方法</title>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
    <script language="javascript">
    /* 定义一弹出窗口,来显示具体内容*/
    function popwin(url)
    {
    window.open(url,"","left=340, top=190, height=280, width=400, resizable=yes, scrollbars=yes, status=no, toolbar=no, menubar=no, location=no");
    }
    </script>
    </head>

    <body leftMargin=0 topMargin=0 rightmargin=0 >

    <?php
    //连接数据库
    $db=mysql_connect("localhost","root","");
    mysql_select_db("XinXiKu",$db);
    //设定每一页显示的记录数
    $pagesize=15;
    //取得记录总数,计算总页数用
    $res=mysql_query("select count(*) from joke " ,$db);
    $myrow = mysql_fetch_array($res);
    $numrows=$myrow[0];
    //计算总页数
    $pages=intval($numrows/$pagesize);
    if ($numrows%$pagesize)
    $pages++;
    //判断页数设置与否,如无则定义为首页
    if (!isset($page))
    $page=1;
    //判断转到页数
    if (isset($ys))
    if ($ys>$pages)
    $page=$pages;
    else
    $page=$ys;
    //计算记录偏移量
    $offset=$pagesize*($page-1);
    //取记录
    $res=mysql_query("select id,biaoti from joke order by id desc limit $offset,$pagesize" ,$db);
    //循环显示记录
    if ($myrow = mysql_fetch_array($res))
    {
    $i=0;
    ?>
    <table width="101%" border="0" cellspacing="0" cellpadding="0">
    <tr>
    <td width="5%" bgcolor="#E1E9FB"></td>
    <td width="95%" bgcolor="#E1E9FB"><font color="#FF6666" size="2">内容</font></td>
    </tr>
    <?php
    do {
    $i++;
    ?>
    <tr>
    <td width="5%" bgcolor="#E6F2FF"><?php echo $i;?></td>
    <td width="95%" bgcolor="#E6F2FF"><font size="2">
    <a href="javascript:popwin('jokenr.php?id=<?php echo $myrow[0];?>')" ><?php echo $myrow[1];?></a></font></td>
    </tr>
    <?php
    }
    while ($myrow = mysql_fetch_array($res));
    echo "</table>" ;
    }
    //显示总页数
    echo "<div align='center'>共有".$pages."页(".$page."/".$pages.")<br>";
    //显示分页数
    for ($i=1;$i<$page;$i++)
    echo "<a href='fy.php?page=".$i."'>第".$i ."页</a>  ";
    echo "第".$page."页  ";
    for ($i=$page+1;$i<=$pages;$i++)
    echo "<a href='fy.php?page=".$i."'>第".$i ."页</a>  ";

    echo "<br>";
    //显示转到页数
    echo "<form action='fy.php' method='post'> ";
    //计算首页、上一页、下一页、尾页的页数值
    $first=1;
    $prev=$page-1;
    $next=$page+1;
    $last=$pages;
    if ($page>1)
    {
    echo "<a href='fy.php?page=".$first."'>首页</a>  ";
    echo "<a href='fy.php?page=".$prev."'>上一页</a>  ";
    }
    if ($page<$pages)
    {
    echo "<a href='fy.php?page=".$next."'>下一页</a>  ";
    echo "<a href='fy.php?page=".$last."'>尾页</a>  ";
    }
    echo "转到<input type=text name='ys' size='2' value=".$page.">页";
    echo "<input type=submit name='Submit' value='Go'>";
    echo "</form>";
    echo "</div>";

    ?>
    </body>
    </html>
    程序说明:

    1、变量说明

    变量$page  :存放当前要显示的页数。

    变量$pages :存放总页数。

    变量$offset :存放当前页数的偏移量。

    变量$pagesize:存放每页中显示的记录数。

    2、MySQL语句说明

    select id,biaoti from joke order by id desc limit $offset,$pagesize
    LIMIT子句用来限制SELECT语句返回的行数。LIMIT中第一个参数指定要返回的第一行的偏移量offset,第二个参数指定返回行的最大数目pagesize。

    实现原理:

    在程序中传递一页数变量page,在取记录时根据传递的页数值来计算出初始记录位置offset,再根据每页中要求显示的记录数pagesize取得记录集。然后显示之。

    程序实现功能:

    程序提供了两种页显示的方法(假定当前页为第三页)。

    1、把所有的页数都显示出来,根据页数提供链接,当前页不提供链接。这适合于页数不是太多的情况。样式如图1所示:

    http://www.ccidnet.com/html/tech/web/2001/05/22/image/1.jpg
    2、提供总页数,翻页通过提供的首页、上一页、下一页、尾页和跳转到来实现。当然,如果当前页为每一页,不提供首页、上一页的链接,当前页为最后一页时,不提供下一页、尾页的链接。样式如图2所示:

    http://www.ccidnet.com/html/tech/web/2001/05/22/image/2.jpg