如何使用MySQL和PHP处理多个搜索结果的分页?

时间:2015-04-05 16:56:45

标签: php mysql pagination search-engine information-retrieval

我正在开发一个Web搜索引擎项目。我正在研究分页功能。当我点击页面时,它会给出突然的结果并给出Undefined variable: page1 error。怎么办?

if(isset($_GET['page'])) //results displayed based on page selection
    {
    $page=$_GET['page'];
    if($page=="" || $page=="1")
    {
        $page1=0;
    }
    else
    {
    $page1=($page*10)-10;
    }
    }

$numrows1 = mysqli_num_rows($query); // page evaluation and this statement calculates number of resultant rows
$a = $numrows1/10; //10 is for number of results per page and $a gives number of pages
$a = ceil($a);
echo "<br>"; echo "<br>";
    for($b=1; $b<=$a; $b++)
    {
        ?><a href="search.php?page=<?php echo $b; ?>" style="text-decoration:none;"><?php echo $b."  ";?></a><?php
    }

我希望我能说清楚。有人可以帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

除非您在URI中有一个页面,否则您似乎永远不会设置页面。

我假设你使用“page.php?page = 1”它不会抛出那个错误,因为$ page1会被设置。

我个人会这样做:

if(isset($_GET['page']) && $_GET['page'] != 1)//if page is set and page doesn't equal 1
{
    $startingRecord = ($_GET['page'] * 10) - 10;
}
else
{
    $startingRecord = 0;
}

此外,我将$page1切换为$startingRecord更有意义,因为您正在计算起始记录,而不是页面。