我有一份注册表格&如果“ID”不存在,我试图插入数据。它的工作正常。现在我试图更新数据,如果'ID'已经存在。它根本不起作用我找不到错误。如果ID存在与否,这里是我设置的条件:
function staff_detail_exist($ic) {
$result = null;
$sql = "SELECT * FROM apply WHERE staffid = '$ic'";
$data = mysql_query($sql);
if (mysql_num_rows($data) == 0) {
$result = "available";
} else {
$result = "exist";
}
return $result;
}
这是我的插页&更新功能:
if (staff_detail_exist($ic) == "available") {
insert_staff_detail($ic, $name, $contact, $mail, $address, $paytype, $applicant);
echo "Workshop application successful! You will be notified shortly via E-mail after confirmation! Thank You!";
}
else if (staff_detail_exist($ic) == "exist") {
update_staff_detail($ic, $name, $contact, $mail, $address, $paytype);
echo "Staff Details Updated!" ;
}
function insert_staff_detail($ic, $name, $contact, $mail, $address, $paytype, $applicant) {
$sql = "INSERT INTO apply (staffid, staffname, staffno, staffemail, staffaddress, paytype, applicant) VALUES ('$ic', '$name', '$contact', '$mail', '$address','$paytype', '$applicant')";
mysql_query($sql);
}
function update_staff_detail($ic, $name, $contact, $mail, $address, $paytype){
$sql = "UPDATE apply
SET staffname='$_POST[name]',
staffno='$_POST[contact]',
staffmail='$_POST[mail]',
address='$_POST[address]',
paytype='$_POST[paytype]'
WHERE staffid='$_POST[ic]'";
mysql_query($sql);
}
有什么建议吗?谢谢!
答案 0 :(得分:1)
观察您必须指明何时收到POST变量。 update_staff_detail
方法应该以与获得insert_staff_detail
方法相同的方式接收POST变量。
更改: update_staff_detail
要强>
function update_staff_detail($ic, $name, $contact, $mail, $address, $paytype){
$sql = "UPDATE apply
SET staffname='$name',
staffno='$contact',
staffmail='$mail',
address='$address',
paytype='$paytype'
WHERE staffid='$ic' LIMIT 1";
mysql_query($sql);
}
问候。