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