如何在 MySQL 中检查两个值


how to check two values in mysql

我正在使用mysql。

我想检查users表中的两个值。

$same_user = "mfalse" ;
$sql=mysql_query("SELECT * FROM users WHERE username='$email' OR phone='$phone'");
        if(mysql_num_rows($sql)>=1)
        {
            $same_user = "mfalse" ;
        }
        else
        {
            $same_user = "mtrue" ;
            mysql_query("SET CHARACTER SET utf8");
            mysql_query("insert into users (username,pass,fname,lname,phone,city)
              VALUES  (N'$email',N'$pass',N'$fname',N'$lname',N'$phone',N'$city')");
        }

        $arr = array(
        'sameuser'=>$same_user);
    return $arr ;

在我的上面的代码中,插入发生了,但从$arr我得到:

{"sameuser":"mfalse"}

为什么?


更新

我的职能 :

function regiterAnUser($an_user){
    //email,pass,fname,lname,phone,city
    $content    = explode("-",$an_user);
    $email      = $content[0];
    $pass       = $content[1];
    $fname      = $content[2];
    $lname      = $content[3];
    $phone      = $content[4];
    $city       = $content[5];
    $pass = md5($pass);

    $same_user = "mfalse" ;
    $sql=mysql_query("SELECT * FROM users WHERE username='$email' OR phone='$phone'");
    if(mysql_num_rows($sql)>=1)
    {
        $same_user = "mfalse" ;
    }
    else
    {
        $same_user = "mtrue" ;
        mysql_query("SET CHARACTER SET utf8");
        mysql_query("insert into users (username,pass,fname,lname,phone,city)
          VALUES  (N'$email',N'$pass',N'$fname',N'$lname',N'$phone',N'$city')");
    }

    $arr = array(
        'sameuser'=>$same_user);
    return $arr ;
}

我不会使用mysql函数,但这是您的选择。

重构了您的代码,它对我有用,请告诉我

function regiterAnUser($an_user){
    $same_user = "mfalse" ;
    //email,pass,fname,lname,phone,city
    $content    = explode("-",$an_user);
    $email      = mysql_real_escape_string($content[0]);
    $pass       = mysql_real_escape_string($content[1]);
    $fname      = mysql_real_escape_string($content[2]);
    $lname      = mysql_real_escape_string($content[3]);
    $phone      = mysql_real_escape_string($content[4]);
    $city       = mysql_real_escape_string($content[5]);
    $pass = md5($pass);
    $sql=mysql_query("SELECT * FROM users WHERE username='$email' OR phone='$phone'");
    if(mysql_num_rows($sql)<1) {
        $same_user = "mtrue" ;
        mysql_query("SET CHARACTER SET utf8");
        mysql_query("insert into users (username,pass,fname,lname,phone,city)
          VALUES  (N'$email',N'$pass',N'$fname',N'$lname',N'$phone',N'$city')");
    }
    return array('sameuser'=>$same_user) ;
}

您是否尝试过输出$sql

无论如何,我建议使用 MySQL 计算行数。看这里。

并且请不要使用mysql_*函数。它们已弃用。例如,请参阅此处。