我尝试实现一个注册表单,并尝试通过php和jQuery检查用户是否已经注册了某个电子邮件。
这是我的代码:
if(endsWith($email, 'domain.tld'))
{
$result = $database->prepare("SELECT id FROM users WHERE email LIKE ?");
$result->bind_param('s', $email);
//echo $email;
$result->execute();
//echo $result->execute();
//echo $result->num_rows;
//exit();
if($result->num_rows == 0)
{
echo'ok';
}
else {
echo 'duplicate';
}
$result->close();
}
else {
echo 'validation failed';
}
我使用了带注释的echos和exit()来调试我的代码。问题是数据库保存了用户user@domain.tld剧本在回音中显示了我"user@domain.tld10".所以语句执行成功,但没有返回任何行。如果我执行语句
SELECT id FROM users WHERE email LIKE "user@domain.tld"
我得到了返回的id(在本例中为11)。
我的问题是,如何更好地调试这个php脚本,最大的问题是为什么我的scipt不能正常工作?
提前感谢您!
在num_rows 之前使用
$result->store_result();
mysqli_stmt_num_rows()的使用取决于您是否使用mysqli_stmt_store_result()来缓冲语句句柄。
单据