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

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

Patricia Arquette
Patricia Arquette原创
2024-11-07 13:37:03244浏览

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

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn