1

我创建了一个文本框,因此当管理员键入名称并单击提交时,它将显示从数据库中检索到的数据列表。

    <form method="post" action="">
        <?php 
        $teacherName = $_POST['teacherName'];
        if ($_POST['submitted'] == 1) {
            if($teacherName != ""){
                $getName = mysql_query("SELECT name, user_id FROM members WHERE name = '$teacherName'");
                $teacherdetails = mysql_fetch_array($getName);
                $teachername = $teacherdetails['name'];
                $teacher_id = $teacherdetails['user_id'];

                if($teachername != ""){
                    print $teachername . "<br/>";
                } else {
                    print "Give a valid name <br/>";
                }     
            }
        }

        if ($teachername == ""){ ?>
        Teacher name:<input type="text" size="20" name="teacherName"><input type="hidden" name="submitted" value="1"><br/>
      <input type="submit" value="Submit" /> 


<?php $getModule = mysql_query("......"); 
          while ($row2 = mysql_fetch_array($getModule)) { ?>   
          <input type="checkbox" name="modules[]" value="<?php print $row2["module_id"]?>"/> <?php print $row2["module_name"] . '<br/>'; } ?>
          </div><br/> <?php } ?>
          <input type="submit" value="Submit" />
</form>

下面我写了这段代码(在同一个脚本中):

<?php

$modules = $_POST['modules'];

for($i = 0; $i < count($modules); $i++){
    $module=mysql_query("INSERT INTO module (module_id,user_id) VALUES ('$modules[$i]','$teacher_id')"); 
}
?>

但是由于某种原因,当我调用变量“$teacher_id”(这是我之前从数据库中检索到的值。它在表单中工作正常)时,它什么也不返回。它是空的,但我不明白为什么。

难道我做错了什么?

4

1 回答 1

0

首先,将 PHP 放在表单标签之外的顶部。

其次,您收到的数据可能是一个数组;具有多个结果集;

这样做只是以防它返回;

 foreach($teacherdetails AS $teacher) {
//also set the values of the variables here
echo $teacher['name'];
echo $teacher['user_id'];

} 

关于最后一点,$teacher_id 是否成功打印了结果?

另外,输入和发布的模块在哪里?

于 2013-03-25T23:29:25.807 回答