我有两个预约表格分别为新患者和已登记的患者, 手机号码被用作主键。表格在php中提交两次
因此,在新的患者注册中,我们检查手机是否已经存在,如果是,则显示错误,否则将新数据输入到表格中。
但是,目前即使当我输入一个新的手机号码,它显示“已经存在”的错误,也输入数据到数据库。
所以我想表单提交了2次,但我无法弄清楚发生了什么。
我的PHP文件中的代码片段是:
if ($_POST['isnewpatient'] == "true") {
@$name = mysql_real_escape_string(trim($_POST['aaptntname']));
@$email = mysql_real_escape_string(trim($_POST['emlid']));
@$mobile = mysql_real_escape_string(trim($_POST['mobile']));
$qqcSql = "select * from " . WP_eemail_TABLE_SUB
. " where eemail_mobile_sub ='" . trim($_POST['mobile'])
. "' OR eemail_patient_id ='" . trim($_POST['mobile']) . "'";
$qqdata1 = $wpdb->get_results($qqcSql);
var_dump($qqdata1);
if (!empty($qqdata1)) {
$err = 1;
echo "<div id='message' class='aerror'>Already patient details exists. Use your existing patient ID !</div>\n";
}
else {
$pt_id = mysql_real_escape_string(trim($_POST['mobile']));
$sql = "insert query to WP_Appointment";
$wpdb->get_results($sql);
$sqls = "insert query to WP_Appointment_Contact";
$wpdb->get_results($sqls);
$sqql = " insert query to table WP_eemail_Table_Sub";
$wpdb->get_results($sqql);
echo "<div id='message' class='asuccess'>Request has been sent for appointment </div>";
}
}
else {
// Already registered patient form
}
<form name="FormEdit" action="<?php echo the_permalink(); ?>" method="post" onsubmit="return p_appointment()" class="aform">
/* Form part */
</form>
JavaScript部分
function p_appointment()
{
if($('input:radio[name=new_patient]:checked').val() == "new")
document.FormEdit.isnewpatient.value = "true";
if($('input:radio[name=new_patient]:checked').val() == "old")
document.FormEdit.isnewpatient.value = "false";
document.FormEdit.appsmssend.value = "true";
document.FormEdit.appemailsend.value = "true";
}
[**'的preventDefault();'**](https://developer.mozilla.org/en/docs/Web /API/event.preventDefault)也许? – 2014-09-29 08:01:07
小心用户双击提交按钮... – 2014-09-29 08:03:17
您是否检查服务器日志以查看表单是否提交了两次? – 2014-09-29 08:10:14