如何使用下拉选项过滤数据

时间:2014-09-22 06:21:49

标签: php mysql filter html.dropdownlistfor

我尝试使用下拉选项过滤一些数据。当用户选择年份/分区并单击过滤器按钮时,它假定从数据库中读取包含该值的所有行。这是我可以去的,它没有工作。真的希望有人可以帮助我。

 if (isset($_GET['do']))
{
    if($_GET['do'] == 'filter')
    {
        if( empty($_POST['key_year']))
        {
            redirect("list.php");
        }
        else
        {   
            $_SESSION['key_year'] = $_POST['key_year'];         
            $_SESSION['key_division'] = $_POST['key_division'];         
        }
    }
    else if($_GET['do'] == 'clear')
    {
        unset($_SESSION['key_year']);
        redirect("list.php");
    }
    else
    {}  
}
$limit = 10;    
$page = ( isset($_GET['page']) ) ? $_GET['page'] : 1;   
$end = ( isset($_GET['page']) ) ? ($limit * $_GET['page']) : $limit;
$offset = ( isset($_GET['page']) ) ? ($limit * $_GET['page']) - $limit : 0;
$start = $offset +1;
$next = $page + 1;
$prev = $page - 1;
$key_year = ( isset($_SESSION['key_year']) ) ? $_SESSION['key_year'] : '';
$key_year = ( isset($_SESSION['key_division']) ) ? $_SESSION['key_division'] : '';

$sql  = "SELECT * FROM tbl_perfomance ";
$sql .= "ORDER BY `p_aid` ASC";
$sql .= " LIMIT $offset, $limit";
$rs = mysql_query($sql);

$sql2="SELECT COUNT(p_aid) AS total FROM tbl_perfomance ";
if(isset($key_year) && isset($key_division))
{
    $sql2 .= "WHERE p_year LIKE '%$key_year%' AND p_division LIKE '%$key_division%'";
}
$rs2=mysql_query($sql2);
$getRec = mysql_fetch_assoc($rs2);
//total
$rowCount=$getRec['total'];
$end = ($end > $rowCount) ? $rowCount : $end;
$total_page = ceil($rowCount/$limit);

$for_start = ( $page <= 2 ) ? 1 : $page - 2;
$for_stop_tmp = $page + 2;
$for_stop  = ( $for_stop_tmp > $total_page ) ? $total_page : $page + 2; 

这是表格。

            <form name="filter" action="list.php?do=filter" method="GET">
                    </label>
                    <label style="color:darkgreen;float:left;width:11%" align="left">
                        Division
                        <select name="key_division">
                            <option value="All">All</option>
                            <option value="ITNT">ITNT</option>
                           <option value="ITP">ITP</option>
                        </select>
                    </label>     -->                
                    <label style="color:darkgreen;float:left;width:11%" align="left">                           
                        Year        
                        <select name="key_year">
                            <option value="all">All</option>
                            <option value="2014">2014</option>
                            <option value="2015">2015</option>
                        </select>
                    </label>
                    <label style="color:darkgreen;float:left;width:11%" align="left">
                    </label><br>
                        <input class="button_green" type="submit" value="Filter &raquo;" /> 

            </form> 

1 个答案:

答案 0 :(得分:0)

我觉得你只是为分页sql添加条件而不是内容sql

尝试更改类似的代码,以便您拥有适当的$sql1$sql2

$sql  = "SELECT * FROM tbl_perfomance ";

$sql2="SELECT COUNT(p_aid) AS total FROM tbl_perfomance ";
if(isset($key_year) && isset($key_division))
{
    $sql2 .= "WHERE p_year LIKE '%$key_year%' AND p_division LIKE '%$key_division%'";
    $sql1 .= "WHERE p_year LIKE '%$key_year%' AND p_division LIKE '%$key_division%'";
}

$sql .= "ORDER BY `p_aid` ASC";
$sql .= " LIMIT $offset, $limit";
$rs = mysql_query($sql);

$rs2=mysql_query($sql2);
$getRec = mysql_fetch_assoc($rs2);

一旦你这样做,就会回显两个查询并直接在php myadmin或任何其他mysql工具中运行它们来检查它们是否正常工作。