繁体   English   中英

MySQL查询行事怪异

[英]MySQL query acting weird

我有:

mysql_connect($host,$username,$password);
@mysql_select_db("db") or die("Error: Cannot select database");
$query = "select password from users where name = '".$_POST['login-userid']."'";
$result = mysql_query($query);

if ($result == false) {
    echo "Invalid username or password";
} else {
    if (mysql_result($result,0) == hash('sha256', $_POST['login-password'])) {
         echo "Logging in...";
    }
}

由于某种原因,即使不应该执行mysql_result行,我也会不断收到错误消息(当用户名不存在时,即$ result的值为false)。

如果有错误, mysql_query只会返回false 在这种情况下,没有错误,只有0行。

您需要使用mysql_num_rows来获取返回的行数。

您可以var_dump($result)查看值,如果它是资源(根据php ),则您的查询成功,如果返回的不是false。 这是布尔值false,但如果确实返回false,则仍应尊重您的==。

mysql_query($query);

返回查询的结果集。 它不会返回truefalse.

您可以使用mysql_num_rows()来检查查询结果是否存在,例如:

if(mysql_num_rows($query)) {
   // exist
} else {
   // does not exist
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM