[英]Count total sum of rows in while loop
好吧,我有这样的查询
$get_downlines = "SELECT * FROM referrals WHERE ref_upline = :rupline";
$get_downlines = $pdo->prepare($get_downlines);
$get_downlines-> bindValue(':rupline', $sessionid);
$get_downlines-> execute();
while($fetch_downlines = $get_downlines->fetch()){
$rdownline = $fetch_downlines['ref_downline'];
$dr = "SELECT * FROM `ads_viewed` WHERE av_user = :user";
$dr = $pdo->prepare($dr);
$dr-> bindValue(':user', $rdownline);
$dr-> execute();
echo $dr_count = $dr->rowCount();
}
上面的代码为我提供了3456
行计数(所有都是单独的计数,例如3、4、5、6)。 现在,我想在这里总结所有这些行,并得到结果为3+4+5+6 = 18
。 并将其分配给一个全局变量,该变量可以在while循环之外的任何地方使用(如果可能)。 如何才能做到这一点?
您可以执行以下操作:
$get_downlines = "SELECT * FROM referrals WHERE ref_upline = :rupline";
$get_downlines = $pdo->prepare($get_downlines);
$get_downlines-> bindValue(':rupline', $sessionid);
$get_downlines-> bindValue(':direct', "direct");
$get_downlines-> execute();
$totalrows;
while($fetch_downlines = $get_downlines->fetch()){
$rdownline = $fetch_downlines['ref_downline'];
$dr = "SELECT * FROM `ads_viewed` WHERE av_user = :user";
$dr = $pdo->prepare($dr);
$dr-> bindValue(':user', $rdownline);
$dr-> execute();
echo $dr_count = $dr->rowCount();
$totalrows+= $dr->rowCount();
}
echo $totalrows;
首先,您创建$totalrows;
循环外的变量。 您可以使用$totalrows += $dr->rowCount();
在查询中$totalrows += $dr->rowCount();
行数来增加此变量$totalrows += $dr->rowCount();
在while循环内
这可以通过一个查询来完成:
$stmt = $pdo->prepare("
SELECT COUNT(*) AS cnt
FROM referrals
JOIN ads_viewed ON ads_viewed.av_user = referrals.ref_downline
WHERE ref_upline = :rupline
");
$stmt->execute(['rupline' => $sessionid]);
$dr_count = $stmt->fetchColumn();
注意:每次在while-fetch-loop中执行SQL查询时,最好使用JOIN。 每次使用SELECT *
只是为了获取行数时,您就在浪费资源,应该使用COUNT(*)
代替。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.