![](/img/trans.png)
[英]PHP Mysql update multiple columns with multiple row values by single query
[英]Count and display multiple mysql row values in different columns for PHP echo
我已经使用以下mysql语句来计数和检索mysql数据库中的多个数据库行:
SELECT COUNT(*) FROM leavesrecords WHERE leavetype IN ('Casual','Annual','Medical') and empno = '202' GROUP BY leavetype
但是此查询的输出仅包含一列,列名称为COUNT(*)
。 该查询返回三个计数值,我希望这些值分配PHP变量。 以下我用来获取值的PHP代码:
include 'database.php';
$query = "SELECT COUNT(*) FROM leavesrecords WHERE leavetype IN ('Casual','Annual','Medical') and empno = '202' GROUP BY leavetype; ";
$stmt = $con->prepare($query);
$stmt->execute();
$num = $stmt->rowCount();
if($num>0){
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
extract($row);
echo $row["leavesrecords"];
}
}
else{ echo "";}
?>
但是这段代码在没有显示单个值的情况下抛出了错误。 我想将这三个mysql计数分配给三个mysql变量。 我怎样才能做到这一点?
您应该为thr列结果使用别名
SELECT COUNT(*) as my_count
FROM leavesrecords
WHERE leavetype IN ('Casual','Annual','Medical') and empno = '202' GROUP BY leavetype
并使用别名的密钥引用该列
if($num>0){
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
// extract($row);
echo $row["my_count"];
}
}
您不应使用表名而是使用正确的列名来引用行内容
考虑在查询中使用IF
或CASE
语句返回单行:
SELECT sum(if(leavetype='Casual',1,0)) AS `CasualCount`,
sum(if(leavetype='Annual',1,0)) AS `AnnualCount`,
sum(if(leavetype='Medical',1,0)) as `MedicalCount`
FROM leaverecords
WHERE leavetype IN ('Casual','Annual','Medical') and empno = '202';
现在,您将有1行包含3个字段。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.