首页 >后端开发 >php教程 >当表有更多行时,为什么 COUNT(*) 在 MySQLi 中返回 1?

当表有更多行时,为什么 COUNT(*) 在 MySQLi 中返回 1?

Barbara Streisand
Barbara Streisand原创
2024-11-10 08:04:02289浏览

Why does COUNT(*) return 1 in MySQLi when the table has more rows?

MySQLi 中的 Count(*) 函数错误计数

在 MySQLi 中执行 COUNT(*) 查询时,用户可能会遇到意外行为,其中无论实际表大小如何,结果始终返回 1。 MySQLi 和 phpMyAdmin 之间的这种差异可能令人费解。

调查和解决方案

出现不匹配是因为 MySQLi 将 COUNT(*) 结果表示为单行记录集。要访问实际计数,必须使用 fetch_row() 方法获取结果。

因此,使用 MySQLi 确定行数的正确方法是:

$result = $db->query("SELECT COUNT(*) FROM `table`");
$row = $result->fetch_row();
echo '#: ', $row[0];

在此修改后在代码中,没有使用 num_rows 属性,因为结果是单行记录集,因此其 rowCount 始终为 1。而是使用 fetch_row() 方法来检索存储在记录集第一列中的实际计数。

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

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