首页 > 后端开发 > php教程 > 为什么 mysqli_num_rows() 返回'期望参数 1 为 mysqli_result,给定布尔值”?

为什么 mysqli_num_rows() 返回'期望参数 1 为 mysqli_result,给定布尔值”?

DDD
发布: 2024-11-28 00:08:12
原创
686 人浏览过

Why Does mysqli_num_rows() Return

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板