调试mySQLi准备的语句->;未找到电子邮件


Debug mySQLi prepared statement -> email not found

我尝试实现一个注册表单,并尝试通过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()来缓冲语句句柄。

单据