我创建了一个文本框,因此当管理员输入名称并单击“提交”时,它将显示数据库中检索到的数据列表。
<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”(这是我之前从数据库中检索到的值。它在表单中工作正常)时,它什么都不返回。它是空的,但我不明白为什么。
我做错了吗?
答案 0 :(得分:0)
首先,将PHP放在表单标签之外,位于顶部。
其次,您收到的数据可能是一个数组;有多个结果集;
这样做只是因为它返回它;
foreach($teacherdetails AS $teacher) {
//also set the values of the variables here
echo $teacher['name'];
echo $teacher['user_id'];
}
关于最后一位,$ teacher_id是否成功打印了一个结果?
此外,从哪里输入和发布模块?