下面的查询给出了exp_judging表中pre字段值为1的行数,其中exp_submissions中也有member_group为5的匹配列
SELECT COUNT(*) AS count_result
FROM exp_judging AS jud
LEFT JOIN exp_submissions AS sub ON jud.rel_id = sub.id
WHERE jud.pre = 1
AND sub.member_group = 5
这很好用。但是,以后'exp_judging'表中会有多行具有相同'rel_id'的行。
如何确保每一行中只有一个被计算在内?
我尝试将 GROUP BY 添加到末尾,但它只显示 1 个结果,而不是之前的 4 个。 (还没有重复)
GROUP BY jud.rel_id
编辑:
已尝试以下,但仍然只显示 1:
SELECT COUNT(DISTINCT jud.rel_id) AS count_result
FROM exp_judging AS jud
LEFT JOIN exp_submissions AS sub ON jud.rel_id = sub.id
WHERE jud.pre = 1
AND sub.member_group = $member_group
GROUP BY jud.rel_id
最佳答案
使用 COUNT(DISTINCT rel_id)
而不是 COUNT(*)
。
关于mysql - 忽略 COUNT 中的重复行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19152968/