查询以从下拉菜单中为给定范围选择值

时间:2018-12-31 19:00:38

标签: php html sql input

我正在制作子宫网站,我想根据下拉菜单中具有不同年龄组的条件进行搜索查询

<select class="form-input" id="age" name="age"  >
    <option value="Age"> <div class="dot"></div> Age</option>
    <option value="1"> <div class="dot"></div> 0-20/option>
    <option value="2"> <div class="dot"> </div>21-30</option>
    <option value="3"> <div class="dot"></div> 31-40</option>
    <option value="4"> <div class="dot"></div> >40 </option>
</select>

我想显示所有满足以上年龄标准的用户 我尝试在sql中使用以上的switch case,但是没有得到任何结果。

$age = mysqli_real_escape_string($db, $_POST['age']);
echo $age;

switch ($age) {
    case 1: $age = ' AND age BETWEEN 100 AND 130 ';  break;
    case 2: $age = ' AND age BETWEEN 131 AND 150 ';  break;
    case 3: $age = ' AND age BETWEEN 151 AND 200 ';  break;
}

$result = mysqli_query($db,
    "SELECT * 
    FROM approved_user 
    WHERE 
        first_name= '$fn'
        OR age=$age "
) or die(mysqli_error($db));

while ($row3 = mysqli_fetch_array($result)) {
    $id     = $row3['id'];
    $fname  = $row3['first_name'];
    $lname  = $row3['surname'];
    $dob    = $row3['dob'];
    $gender = $row3['gender'];
    $age    = $row3['age'];
}

所以请帮助。

1 个答案:

答案 0 :(得分:0)

您生成的查询没有任何意义。

给出以下值,例如:

$age = "  AND age BETWEEN 100 AND 130 ";

此表达式:

"SELECT * FROM approved_user WHERE (first_name= '$fn') OR  (age=$age)"

实际上会生成:

"SELECT * FROM approved_user WHERE (first_name= '$fn') OR  (age= AND age BETWEEN 100 AND 130)"

这是无效的SQL。您可能想要:

switch ($age) {
    case 1: $filter = "100 AND 130";  break; 
    case 2: $filter = "131 AND 150";  break;  
    case 3: $filter = "151 AND 200";  break;   
 }

 $result = mysqli_query($db,
    "SELECT *
    FROM approved_user 
    WHERE 
        first_name= '$fn' 
        OR age BETWEEN $filter"
) or die(mysqli_error($db));