mysql在一个组中计数

时间:2009-09-17 13:35:35

标签: sql mysql count

假设我有一个投票表,用户可以在其中对值进行投票,向上或向下投票。 假设每次进行corrcet投影时用户都会得到一个点。

在每周结束时,我想显示一些统计数据。

类似的东西:

SELECT user_id, sum( user_points ) as sum_points FROM voting_results
WHERE voting_date > ('2009-09-18' - INTERVAL 1 WEEK)
GROUP BY user_id 
ORDER BY sum_points DESC

精细。这将为我提供一个很好的列表,其中“最佳猜测”用户首先出现。

这是我的问题:

我如何 - 在同一查询中 - 获取每个用户在给定时间段内投票的次数?

换句话说:我想要一个计数 - 每行 - 需要包含在上述查询中用user_id找到的行数。

有什么建议吗?

感谢。

1 个答案:

答案 0 :(得分:5)

只需添加COUNT(*)

SELECT  user_id,
        SUM(user_points) as sum_points,
        COUNT(*) AS num_votes
FROM    voting_results
WHERE   voting_date > ('2009-09-18' - INTERVAL 1 WEEK)
GROUP BY
        user_id 
ORDER BY
        sum_points DESC