将下拉列表中的值插入另一个 table 的数据库

Inserting a value from dropdownlist to database from another table

我的学生 activity 项目中有两个 table。 (一个 table(name : evidall) 我存储主题的地方(在我的代码中,它们是外语 'predmet' )我还有另一个 table( name : evid_record ) 我有一个脚本来放入有关学生的数据,我有一个下拉列表,它从第一个 table(evidall) 中提取主题的名称。我设法让它将数据拉到下拉列表中,但是当我 select 下拉列表中的任何主题时,它不会将其保存到第二个 table(evid_record)。我已经尝试了好几天了,但我真的没有知道我做错了什么。我在网上找到的所有内容都是针对下拉列表中写入的直接值,但我的情况比那更具体..

这是我的 DDL 的代码和形式:

    <body>

   <div class="forma">
       <form action="snimipodatkestud.php" method="Post">
           <fieldset>

    <span class="FieldInfo">Ime:</span><br><input type="text" name="imes" value=""><br>
    <span class="FieldInfo">Prezime:</span><br><input type="text" name="prezimes" value=""><br>
    <span class="FieldInfo">Broj indeksa: </span><br><input type="text" name="indeksbr" value=""><br>
    <span class="FieldInfo">Predmet: <br>
                    <select name="zpredmet">

                             <option>Choose one..</option>
                                       <option name="izpredmet" value="
                      <?php   

                                $ViewQuery="SELECT epredmet FROM evidall";
                                $Execute= mysqli_query($connection, $ViewQuery);

                                          while($datarows=mysqli_fetch_array($Execute)){
                                                echo "<option value=\"\">" . $datarows['epredmet'] . "</option>";
    }                       
                                             ?>" ></option>
                              <br></select><br>

    <span class="FieldInfo">Teorija kolokvijum:</span><br><input type="text" name="teorija" value=""><br>
    <span class="FieldInfo">Zadaci kolokvijum: </span><br><input type="text" name="zadaci" value=""><br>
    <span class="FieldInfo">Aktivnost: </span><br><input type="text" name="akt" value=""><br>
    <span class="FieldInfo">Prisustvo: </span><br><input type="text" name="pris" value=""><br>
    <span class="FieldInfo">Seminarski rad: </span><br><input type="text" name="semrad" value=""><br>
    <span class="FieldInfo">Domaci rad: </span><br><input type="text" name="domrad" value=""><br>

              <div class="klgg">
   <br><input type="submit" name="submit" value="Upisi"><br>
             </div>

              <br><?php echo $NEuspehupis; ?><br>
               <br><?php echo $uspehupis; ?><br> 
           </fieldset>


       </form>


   </div>




</body>

这是插入部分:

<?php include("konekcija.php");?>
<?php

    global $connection;
    global $uspehupis;
    global $NEuspehupis;

$ime = $prezime = $izpredmet = $teorija = $zadaci = $akt = $pris = $semrad = $domrad = $indeksbr =  "";


if(isset($_POST["submit"])){

if(!empty($_POST["imes"]) && !empty($_POST["indeksbr"])){



    $ime= $_POST["imes"];
    $prezime= $_POST["prezimes"];
    $indeksbr= $_POST["indeksbr"];
    $izpredmet= $_POST["izpredmet"];
    $teorija= $_POST["teorija"];
    $zadaci=  $_POST["zadaci"];
    $akt = $_POST["akt"];
    $pris= $_POST["pris"];
    $semrad= $_POST["semrad"];
    $domrad= $_POST["domrad"];


    $query= "INSERT INTO evid_record(imes,prezimes,indeksbr, predmet, teorija, zadaci, akt, pris, semrad, domrad) 
             VALUES ('$ime', '$prezime','$indeksbr','$izpredmet', '$teorija', '$zadaci', '$akt', '$pris', '$semrad', '$domrad')";





     $execute=mysqli_query($connection, $query);

    if($execute){
            $uspehupis = "<div class='alert alert-success alert-dismissible'>
  <a href='#' class='close' data-dismiss='alert' aria-label='close'>&times;</a>
  <strong>Registracija uspesna!</strong></div>";

    }
}
    else{

        $NEuspehupis = "<div class='alert alert-danger fade in alert-dismissible'>
  <a href='#' class='close' data-dismiss='alert' aria-label='close'>&times;</a>
  <strong>Morate uneti ime,prezime, email i sifru!</strong></div>";



}

  $query1 ="UPDATE evid_record SET `ukupno` = (teorija + zadaci + akt + pris + semrad + domrad)";

    $execute1=mysqli_query($connection, $query1);

}






?>

有几个问题:

1) $izpredmet= $_POST["izpredmet"]; ...但在您的表格中您有 <select name="zpredmet">。名称不匹配,所以 $_POST["izpredmet"];永远不会包含任何值。

2) <option name="izpredmet" 无效 - 个别选项没有名称,它们不是表单字段,因此从此处删除 "name" 属性

3) <option value=\"\" 您将选项的所有值设为空白,因此即使您正确提交了该字段,也不会提供任何值 - 表单将提交一个空字符串作为所选值.您需要在选项的 "value" 属性中设置一个合适的值。如果你没有单独的ID作为值,你可以只写

echo "<option value=\"".$datarows['epredmet']."\">" . $datarows['epredmet'] . "</option>";