PHP变量返回null值

时间:2013-03-25 23:21:47

标签: php html mysql forms textbox

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

    <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”(这是我之前从数据库中检索到的值。它在表单中工作正常)时,它什么都不返回。它是空的,但我不明白为什么。

我做错了吗?

1 个答案:

答案 0 :(得分:0)

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

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

这样做只是因为它返回它;

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

} 

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

此外,从哪里输入和发布模块?