[英]How to get count of rows in MySQL table using PHP?
我只是想使用 PHP 来计算 MySQL 表中的总行数,并将该数字存储在名为$count
的变量中。
我更喜欢过程代码,因为我的思想不能以面向对象的方式工作。
$sql="SELECT COUNT(*) FROM news";
$result = mysqli_query($con, $sql);
$count = mysqli_fetch_assoc($result);
echo $count;
以上是我尝试过的最新版本。 它没有给我一个数字,而是给了我“数组”这个词。
您有几个选择如何从 SQL 获取COUNT(*)
的值。 最简单的三个可能是这样的:
$sql = "SELECT COUNT(*) FROM news";
$result = mysqli_query($con, $sql);
$count = mysqli_fetch_assoc($result)['COUNT(*)'];
echo $count;
或使用列别名:
$sql = "SELECT COUNT(*) as cnt FROM news";
$result = mysqli_query($con, $sql);
$count = mysqli_fetch_assoc($result)['cnt'];
echo $count;
或使用数值数组:
$sql = "SELECT COUNT(*) FROM news";
$result = mysqli_query($con, $sql);
$count = mysqli_fetch_row($result)[0];
echo $count;
不要按照 web 上某些地方的建议使用mysqli_num_rows
来统计数据库中的记录。 这个function用处很少,计数记录绝对不是其中之一。 使用mysqli_num_rows
您将要求 MySQL 从数据库中检索所有匹配的记录,这可能非常耗费资源。 最好将计数记录的工作委托给 MySQL,然后在 PHP 中获取返回值,如我的回答所示。
我还建议学习 OOP,它可以使您的代码更清晰,更易于阅读。 与 OOP 相同,可以按如下方式进行:
$sql = "SELECT COUNT(*) FROM news";
$count = $con->query($sql)->fetch_row()[0];
echo $count;
如果您的查询使用变量,那么您可以做类似的事情,但使用准备好的语句。
$sql = "SELECT COUNT(*) FROM news WHERE category=?";
$stmt = $con->prepare($sql);
$stmt->bind_param('s', $category);
$stmt->execute();
$count = $stmt->get_result()->fetch_row()[0];
echo $count;
最好使用 COUNT(*) 而不是选择所有行并使用mysqli_num_rows()
。
您的基本想法是正确的,您只需要正确获取结果即可。
$sql = "SELECT COUNT(*) FROM news";
$count = 0;
if ($result = mysqli_query($con, $sql)) {
$row = mysqli_fetch_row($result);
$count = $row[0];
}
echo $count;
下面的PHP可以用来执行查询计算结果量:
$sql="SELECT COUNT(*) AS news_count FROM news";
$result = mysqli_query($con, $sql);
$row = mysqli_fetch_array($result);
$count = $row['news_count'];
echo $count;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.