[英]MySQL Multiple Counts in Single Query
I am trying to COUNT two columns in a single query, but the results are spitting out the same values for medcount and uploadcount. 我试图在一个查询中计算两列,但结果是为medcount和uploadcount分配相同的值。 Any suggestions? 有什么建议?
SELECT * , COUNT($tbl_list.listname) AS listcount,
COUNT($tbl_uploads.id) AS uploadcount
FROM $tbl_members
LEFT JOIN $tbl_list ON $tbl_members.username = $tbl_list.username
LEFT JOIN $tbl_uploads ON $tbl_members.username = $tbl_uploads.username
GROUP BY $tbl_members.username
ORDER BY $tbl_members.lastname, $tbl_members.firstname;
Use: 使用:
SELECT tm.*,
x.listcount,
y.uploadcount
FROM $tbl_members tm
LEFT JOIN (SELECT tl.username,
COUNT(tl.listname) AS listcount
FROM $tbl_list tl
GROUP BY tl.username) x ON x.username = tm.username
LEFT JOIN (SELECT tu.username,
COUNT(tu.id) AS uploadcount
FROM $tbl_uploads tu
GROUP BY tu.username) y ON y.username = tm.username
GROUP BY tm.username
ORDER BY tm.lastname, tm.firstname
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.