SQL复选框搜索显示我数据库中的项目列表



我正在设置一个目录页面,该页面根据文本字段(有效(和/或复选框(不起作用(

来显示不同的锻炼。

我不知道没有提交按钮是否可以,但我希望它可以搜索项目并让其搜索多个复选框

我尝试在互联网上寻求帮助,但找不到与我的项目相关的任何东西。

$sqlBrowse = "SELECT * FROM workoutLibrary
                WHERE name LIKE :findInName
                OR bodyPart  LIKE :findInBodyPart
                OR muscleGroup LIKE :findInMuscleGroup
                OR equipment LIKE :findInEquipment
                ORDER BY name";
$searchTerm = '';
$search = '%';
if (isset($_POST['search'])) {
    $searchTerm = $_POST['search'];
    $search = '%' . $searchTerm . '%';
    $stmt = $conn->prepare($sqlBrowse);
    $stmt->bindParam(":findInName", $search);
    $stmt->bindParam(":findInBodyPart", $search);
    $stmt->bindParam(":findInMuscleGroup", $search);
    $stmt->bindParam(":findInEquipment", $search);
    $stmt->execute();
    $exercises = $stmt->fetchAll();
}
else if (isset($_POST['checklist'])) {
    $searchTerm = $_POST['checklist'];
    $search = '%' . $searchTerm . '%';
    $stmt = $conn->prepare($sqlBrowse);
    $stmt->bindParam(":findInEquipment", $search);
    $stmt->execute();
    $exercises = $stmt->fetchAll();
}
?>

html:

<form action="directory.php" method="post">
   <input type="checkbox" name="checklist[]" class="check" value="Dumbell"> Dumbbell<br>
   <input type="checkbox" name="checklist[]" class="check" value="kettlebell"> Kettlebell<br>
</form>
      <div class="col-sm-10">
          <h1 class="theTitle"> Workout Directory </h1>
            <div class="d-flex flex-wrap">
              <?php
                foreach ($exercises as $exercise) {
               ?>
                <div class="card" id="workoutCard">
                  <div class="card-header"> <?= $exercise->name ?> </div>
                  <div class="card-body">
                      <div class="thumbnail"> </div>
                        <div class="info">
                          <a id="subTitle">Body Parts:</a> <?= $exercise->bodyPart ?><BR>
                          <a id="subTitle">Muscle Group:</a> <?= $exercise->muscleGroup ?><BR>
                          <a id="subTitle">Equipment Used:</a> <?= $exercise->equipment ?>
                        </div>
                  </div>
                </div>
            <?php
            }
            ?>

我的搜索栏非常完美,因此我没有为此显示HTML。我是初学者,所以我不确定自己出了问题,我不确定我是否可以在同一名称变量下执行两个PDO陈述。

任何帮助或提示都将不胜感激

更新:一个复选框现在将显示所有相关信息(没有清单[](,但对其中的两个不起作用(我相信我需要清单[]才能使两个工作起作用(所以我的新问题是,我该如何做:

$ search ='%'。$搜索期。'%';

显示的范围

更多

我假设您希望您的表格在用户选中复选框时退回吗?如果是这样,请将单击事件添加到发布表格的复选框,例如

<input type="checkbox" name="checklist[]" class="check" onclick='document.forms[0].submit();' value="Dumbell"> Dumbbell<br>
   <input type="checkbox" name="checklist[]" class="check" onclick='document.forms[0].submit();'  value="kettlebell"> Kettlebell<br>

对于字符串转换错误的数组,这是由于表单字段中的清单属性。

当您使用清单[](这是一个数组(时,您将必须循环获得值:

     else if (isset($_POST['checklist'])) {
     $searchArray = $_POST['checklist'];
     foreach ($searchArray as $searchTerm)
      { 
         $search = '%' . $searchTerm . '%';
         $stmt = $conn->prepare($sqlBrowse);
         $stmt->bindParam(":findInEquipment", $search);
         $stmt->execute();
         $exercises = $stmt->fetchAll();
      }     
}  

最新更新