PHP 和 MySQL 中的 mysqli_num_rows() 函数错误:详细指南
问题:
调用mysqli_num_rows()函数时,报错遇到“mysqli_num_rows() 期望参数 1 为 mysqli_result,给定布尔值”。此错误表明传递给函数的参数有问题。
分析和解决方案:
mysqli_num_rows() 函数期望第一个参数是有效的 mysqli_result 对象。在提供的代码中,$dbc 被错误地用作参数。然而,检查代码发现 $dbc 是 mysqli_query() 调用的结果。
实际问题在于查询本身。该查询尝试在“users”和“profile”表之间执行 INNER JOIN。但是,查询中没有指定显式 JOIN 条件。这会导致查询返回 false,然后将其传递给 mysqli_num_rows() 函数并触发错误。
要解决此问题,您需要在查询中指定有效的 JOIN 条件。在这种情况下,您可能应该在 user_id 字段上加入“users”和“profile”。更正查询后,它应该返回一个有效的 mysqli_result 对象,然后可以将其传递给 mysqli_num_rows() 函数。
更正的查询:
$dbc = mysqli_query($mysqli, " SELECT users.*, profile.* FROM users INNER JOIN profile ON users.user_id = profile.user_id WHERE users.user_id=3 ");
通过此调整,查询应该成功执行,返回一个可由 mysqli_result 对象使用mysqli_num_rows() 函数不会触发错误。
以上是为什么 mysqli_num_rows() 返回'期望参数 1 为 mysqli_result,给定布尔值”?的详细内容。更多信息请关注PHP中文网其他相关文章!