Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/244.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
php mysql过滤分页结果不';我不在下一页工作_Php_Mysql_Pagination - Fatal编程技术网

php mysql过滤分页结果不';我不在下一页工作

php mysql过滤分页结果不';我不在下一页工作,php,mysql,pagination,Php,Mysql,Pagination,你好。我需要你的专家意见。我一直在使用mysql的过滤结果进行分页 过滤结果仅在第一页上有效。单击下一页或后续页,我会看到下面的错误,它也会显示数据库中的所有数据 注意:未定义索引:搜索注意:未定义索引:位置 通知:未定义索引:部门通知:未定义索引:建筑 等等 我想知道我会错过什么 以下是更新的代码: 创建分页链接时,没有在创建的链接中添加查询参数,这就是转到下一页时参数丢失的原因 因此,无论您在何处创建这样的分页链接 $paginate.=” 与pagenum一起添加搜索的参数。例如(添加

你好。我需要你的专家意见。我一直在使用mysql的过滤结果进行分页

过滤结果仅在第一页上有效。单击下一页或后续页,我会看到下面的错误,它也会显示数据库中的所有数据

注意:未定义索引:搜索注意:未定义索引:位置 通知:未定义索引:部门通知:未定义索引:建筑 等等

我想知道我会错过什么

以下是更新的代码:


创建分页链接时,没有在创建的链接中添加查询参数,这就是转到下一页时参数丢失的原因

因此,无论您在何处创建这样的分页链接

$paginate.=”

与pagenum一起添加搜索的参数。例如(添加搜索项)

$paginate.=”

除此之外,您似乎还从$\u POST变量获取数据,现在当您在链接上添加参数时,您必须通过$\u get获取它们 像

$\u GET['search']
等等

假设第一次进行搜索时,它是使用表单上的
method=“post”
发送的,如果适合您的用例,您也可以将其更改为
method=“get”

更新:

您需要将查询参数添加到所有链接,而不仅仅是一个位置。

因此,您可以首先创建一个变量,该变量已经连接了所有查询参数

$params=“&search=$search&position=$position&dept=$dept&‌​屋宇=$bldg”

然后,无论你在哪里编写代码

在此处添加params变量,如下所示:


请记住,这需要在代码中通过
?page=
的所有位置执行,或者只检查更新的链接进行测试。

创建分页链接时,您没有在创建的链接中添加查询参数,这是转到下一页时参数丢失的原因

因此,无论您在何处创建这样的分页链接

$paginate.=”

与pagenum一起添加搜索的参数。例如(添加搜索项)

$paginate.=”

除此之外,您似乎还从$\u POST变量获取数据,现在当您在链接上添加参数时,您必须通过$\u get获取它们 像

$\u GET['search']
等等

假设第一次进行搜索时,它是使用表单上的
method=“post”
发送的,如果适合您的用例,您也可以将其更改为
method=“get”

更新:

您需要将查询参数添加到所有链接,而不仅仅是一个位置。

因此,您可以首先创建一个变量,该变量已经连接了所有查询参数

$params=“&search=$search&position=$position&dept=$dept&‌​屋宇=$bldg”

然后,无论你在哪里编写代码

在此处添加params变量,如下所示:



请记住,这需要在代码中通过
?page=
的所有位置执行,或者只检查更新的链接进行测试。

不要使用mysql。它在PHP7中被删除。似乎我需要重新编写所有代码?以使您的应用程序更好是的。您可以改用PDO/Mysqli。单击分页链接时传递筛选器参数。然后使用
$\u REQUEST
读取筛选值,这样它就可以在get和post方法中工作了。我该怎么做?对不起,我是编程新手。我应该在哪里插入它?不要使用mysql。它在PHP7中被删除。似乎我需要重新编写所有代码?以使您的应用程序更好是的。您可以改用PDO/Mysqli。单击分页链接时传递筛选器参数。然后使用
$\u REQUEST
读取筛选值,这样它就可以在get和post方法中工作了。我该怎么做?对不起,我是编程新手。那么我应该在哪里插入它呢?哦,好的,即使我更改了form方法以获得$paginate,我也会同样尝试再次初始化;我还将表单方法从post更改为get。但是没有avail@alex您需要更新所有链接以获得搜索参数。我已经为您更新了答案。哦,好的,即使我更改了form方法以获得$paginate,我也会尝试同样的方法;我还将表单方法从post更改为get。但是没有avail@alex您需要更新所有链接以获得搜索参数。我已经为你更新了答案。
<?php
    include('include/connect.php'); 

    $tableName="employee";      
    $targetpage = "searchresults.php";  
    $limit = 5; 


    $search = mysql_real_escape_string($_GET['search']);
    $position = mysql_real_escape_string($_GET['position']);
    $dept = mysql_real_escape_string($_GET['dept']);
    $bldg = mysql_real_escape_string($_GET['bldg']);

    $query = "SELECT COUNT(*) as num FROM $tableName WHERE name like '%{$search}%' AND position like '%{$position}%' AND dept like '%{$dept}%' AND bldg like '%{$bldg}%'";
    $total_pages = mysql_fetch_array(mysql_query($query));
    $total_pages = $total_pages['num'];

    $stages = 3;



    //  $page = mysql_escape_string($_GET['page']);


    $page = isset($_GET['page']) ? mysql_real_escape_string($_GET['page']) : 0;



    if($page){          
        $start = ($page - 1) * $limit; 
    }else {
        $start = 0; 
    }

    // Get page data

    $query1 = "SELECT * FROM $tableName WHERE ads like '%{$search}%' AND position like '%{$position}%' AND dept like '%{$dept}%' AND bldg like '%{$bldg}%' ORDER BY dateposted DESC LIMIT $start, $limit";
    $result = mysql_query($query1);

    // Initial page num setup
    if ($page == 0){$page = 1;}
    $prev = $page - 1;  
    $next = $page + 1;                          
    $lastpage = ceil($total_pages/$limit);      
    $LastPagem1 = $lastpage - 1;                    

    $paginate = '';
    if($lastpage > 1)
    {   




        $paginate .= "<div class='paginate'>";
        // Previous
        if ($page > 1){
            $paginate.= "<a href='$targetpage?page=$prev'>previous</a>";
        }else{
            $paginate.= "<span class='disabled'>previous</span>";   }



        // Pages    
        if ($lastpage < 7 + ($stages * 2))  // Not enough pages to breaking it up
        {   
            for ($counter = 1; $counter <= $lastpage; $counter++)
            {
                if ($counter == $page){
                    $paginate.= "<span class='current'>$counter</span>";
                }else{
                    $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
            }
        }
        elseif($lastpage > 5 + ($stages * 2))   // Enough pages to hide a few?
        {
            // Beginning only hide later pages
            if($page < 1 + ($stages * 2))       
            {
                for ($counter = 1; $counter < 4 + ($stages * 2); $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1&search=$search&position=$position&dept=$dept&‌​bldg=$bldg''>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";       
            }
            // Middle hide some front and some back
            elseif($lastpage - ($stages * 2) > $page && $page > ($stages * 2))
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $page - $stages; $counter <= $page + $stages; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
                $paginate.= "...";
                $paginate.= "<a href='$targetpage?page=$LastPagem1&search=$search&position=$position&dept=$dept&‌​bldg=$bldg'>$LastPagem1</a>";
                $paginate.= "<a href='$targetpage?page=$lastpage'>$lastpage</a>";       
            }
            // End only hide early pages
            else
            {
                $paginate.= "<a href='$targetpage?page=1'>1</a>";
                $paginate.= "<a href='$targetpage?page=2'>2</a>";
                $paginate.= "...";
                for ($counter = $lastpage - (2 + ($stages * 2)); $counter <= $lastpage; $counter++)
                {
                    if ($counter == $page){
                        $paginate.= "<span class='current'>$counter</span>";
                    }else{
                        $paginate.= "<a href='$targetpage?page=$counter'>$counter</a>";}                    
                }
            }
        }

                // Next
        if ($page < $counter - 1){ 
            $paginate.= "<a href='$targetpage?page=$next'>next</a>";
        }else{
            $paginate.= "<span class='disabled'>next</span>";
            }

        $paginate.= "</div>";       


}
 echo $total_pages.' Results';
 // pagination
 echo $paginate;

?>

<ul>

<?php 

        echo "<table id='t01' border='5' style='width:100%' align='center'>";

                echo "<tr>";                                 
                    echo "<th>NAME</th>";
            echo "<th>CONTACT</th>";
            echo "<th>DEPT</th>";
            echo "<th>BLDG</th>";   
            echo "<th>POSITION</th>";   
                    echo "<th>COMMENT</th>";

                echo "</tr>";




        while($row = mysql_fetch_array($result))
        {

        // echo '<li>'.$row['user'].'</li>';

        echo "<tr>";                    

                    echo "<td>" . $row['user'] . "</td>";

            echo "<td>" . $row['contact'] . "</td>";

            echo "<td>" . $row['dept'] . "</td>";   

            echo "<td>" . $row['bldg'] . "</td>";

            echo "<td>" . $row['position'] . "</td>";   

                    echo "<td>" . $row['comment'] . "</td>";


                echo "</tr>";







        }





    ?>