[英]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);
返回查询的结果集。 它不会返回true
或false.
您可以使用mysql_num_rows()
来检查查询结果是否存在,例如:
if(mysql_num_rows($query)) {
// exist
} else {
// does not exist
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.