首页 > 后端开发 > php教程 > 为什么MySQLi的count(*)在计算表行数时返回1?

为什么MySQLi的count(*)在计算表行数时返回1?

Patricia Arquette
发布: 2024-11-07 13:37:03
原创
346 人浏览过

Why Does MySQLi's `count(*)` Return 1 When Counting Table Rows?

MySQLi 的 count(*) 意外返回 1

在使用 MySQLi 统计 MySQL 表的行数时,你可能会遇到一个奇怪的现象,$result-> ;num_rows 始终报告计数为 1。让我们研究一下正确的方法。

问题在于 MySQLi 如何处理 COUNT(*) 查询的结果。与包含一组行的普通查询的结果不同,COUNT(*) 返回包含计数的单行和单列。

要准确检索此计数,您需要获取单行从结果集中。以下代码演示了正确的用法:

$result = $db->query("SELECT COUNT(*) FROM `table`");
$row = $result->fetch_row();
$count = $row[0];

echo "Count: $count";
登录后复制

通过获取第一行(也是唯一的)行并访问其第一列,您可以获得正确的计数。使用 $result->num_rows 将始终返回 1,因为它表示结果集中的行数,对于 COUNT(*) 查询,该行数为 1。

请记住,对于结果包含多行的普通查询,使用 $result->num_rows 是合适的。但是,对于 COUNT(*) 查询,请始终遵循上述模式来检索实际计数。

以上是为什么MySQLi的count(*)在计算表行数时返回1?的详细内容。更多信息请关注PHP中文网其他相关文章!

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