尝试为我的表单设置正确的唯一条目


Trying to get Unique entries set right for my form

所以我搜索了这个问题并找到了类似的问题,但我不确定如何将他们的解决方案翻译成我的 - 主要是因为我是 PHP 的菜鸟。我正在努力。请耐心等待。我感谢您的帮助!

现在,我正在尝试使我的表单不允许phpmysql中电子邮件列的重复条目。 到目前为止,我进入了那里的结构选项卡,并使其独一无二。几乎是中提琴。 但是,我希望在提交表单时在同一页面上显示错误消息,而不是重新加载它并给出消息。 另外,我想自定义消息。 看到这是一个与phpmysql相关的错误,我不确定我是否会使用PHP编码或那里的某个地方来做到这一点。

谢谢大家。我很感激你的帮助。

<?php
function checkField($v){
    return (isset($v) && $v === false) ? true: false;
}
function startMysql(){
    $con=mysqli_connect("localhost", "shiftedr_admin", "passwerd", "shiftedr_whosthedeeusers"); 
    // Check connection
    if (mysqli_connect_errno()){
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    } else {
        return null;
    }
    return $con;
}
//  function closeMySql($connection){
//      mysqli_close($connection);
//  }
function formcheck(){
    $con=mysqli_connect("localhost", "shiftedr_admin", "shithead1", "shiftedr_whosthedeeusers"); 
    // Check connection
    if (mysqli_connect_errno()){
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    } else { 
        if (isset($_POST['submitted'])){
            $form = null;
            if (empty($_POST['fullname'])){
                $form['fullnameflag'] = false;
            } 
            if (empty($_POST['email'])){
                $form['emailflag'] = false;
            } 
            if (empty($_POST['password'])){
                $form['passwordflag'] = false;
            } 
            if (empty($_POST['pwc'])){
                $form['pwcflag'] = false;
            } 
            if (empty($_POST['userbday'])){
                $form['userbday'] = false;
            }
            if (empty($_POST['gender'])){
                $form['genderflag'] = false;
            } 
            if ($_POST['password'] != $_POST['pwc']){
                $form['fixpasswordconfirm'] = false;
            }

            /*$query = mysql_query ("SELECT * FROM users2  WHERE email = '". Email'" ."'");
          if (mysql_num_rows($query) > 0) 
            { 
 echo 'Email Address is Already In Use.'; 
            }*/
            if (empty($form)) { // all fields correct at this point, do database stuff
                $sql="INSERT INTO Users2 (fullname, Email, Password, userbday, Gender) VALUES ('".$_POST['fullname']."','".$_POST['email']."','".$_POST['password']."','".$_POST['userbday']."','".$_POST['gender']."')";
                if (!mysqli_query($con,$sql)){
                    die('Error: ' . mysqli_error($con));
                }
                echo "1 record added";
            }
        }
        mysqli_close($con);
        return $form;
    }
}
//// /  include("myfunctions.php");
?>

我猜你有两个页面 - myform.php和process.php或类似的东西,所以尝试这样做

<?php
$error = null; 
if( isset( $_POST['submitted'] ) ) // Same as your check is submitting if
{
    // Below is an example fail
    if( empty( $_POST['fullname'] ) ) $error = 1;
    // So for the email address failing you would put
    if( mysql_num_rows($query) > 0 ) $error = 2;
    if(! $error )
    {
        // all good no errors here so do database stuff....
    }
    else
    {
    header("Location: form.php?error=$error"); // return the error code to previous page
    }
}
?>

如果一个可能是空字段,或者可能是全名是空的,两个是使用的电子邮件地址或类似的东西,在你的myform上.php页面上有

 <?php
if( isset( $_GET['error'] ) )
{
    switch ( $_GET['error'] )
    {
        case 1 : echo "One of the fields is empty"; break;
        case 2 : echo "Your email address has already been used"; break;
        default : echo "Unknown error occured";
    }
}
?>