gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 23:45:40 25 4
gpt4 key购买 nike

我尝试使用下拉选项过滤一些数据。当用户选择年份/部门并单击筛选按钮时,它假设从数据库中读取包含该值的所有行。这是我所能做到的,但没有成功。真的希望有人能帮助我。

 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>

最佳答案

我觉得你只是为分页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 工具中运行它们来检查它们是否正常工作。

关于php - 如何使用下拉选项过滤数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25967771/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com