我尝试使用复选框更新数据。但是,如果未选中一个或多个复选框,则会返回一条通知:
注意:未定义的索引:第12行的E:\ wamp \ www \ HOSPITAL \ update.php中的stats2
注意:未定义的索引:第12行的E:\ wamp \ www \ HOSPITAL \ update.php中的stats3
注意:未定义的索引:第12行的E:\ wamp \ www \ HOSPITAL \ update.php中的stats5
<?php
$con = mysql_connect("localhost","root","");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("Hospital", $con);
mysql_query("UPDATE t2 SET HOSPNUM ='$_POST[hnum]', ROOMNUM='$_POST[rnum]', ADDATE= '$_POST[ad8]', ADTIME='$_POST[adtym]', LASTNAME='$_POST[lname]', FIRSTNAME='$_POST[fname]', MIDNAME='$_POST[mname]', CSTAT='$_POST[cs]', AGE='$_POST[age]', BDAY='$_POST[bday]', ADDRESS='$_POST[ad]', SEX='$_POST[sex]',
STAT='$_POST[stats1]', STAT2='$_POST[stats2]', STAT3='$_POST[stats3]', STAT4='$_POST[stats4]', STAT5='$_POST[stats5]', STAT6='$_POST[stats6]', STAT7='$_POST[stats8]', STAT8='$_POST[stats8]', NURSE='$_POST[nurse]'
WHERE TELNUM ='$_POST[telnum]'");
mysql_close($con)
?>
您能帮我,使通知不显示吗?
最佳答案
这是复选框的已定义行为-仅在选中复选框后,它们才包含在表单数据中。
您应该使用isset()确定该复选框是否被选中。
更改为
STAT='".isset($_POST['stats1']).",
STAT2='".isset($_POST['stats2']).",
STAT3='".isset($_POST['stats3']).",
STAT4='".isset($_POST['stats4']).",
STAT5='".isset($_POST['stats5']).",
STAT6='".isset($_POST['stats6']).",
STAT7='".isset($_POST['stats8']).",
STAT8='".isset($_POST['stats8'])."
另一个可行的解决方法是在复选框前添加一个具有相同名称的隐藏变量:
<form action='t1.php' method='post'>
<input type='hidden' name="cb1" value="0">
<input type='checkbox' name="cb1" title='test'>
<input type='submit' >
</form>
<?php
print_r($_POST);
?>