MySQL查找每个用户的帖子总数

时间:2010-02-03 23:50:53

标签: sql mysql

我有一个包含以下两个表的数据库, USERS,POSTS 我正在寻找一种方法来计算用户有多少帖子。

Users            Posts
+----+------+    +----+---------+-----------+
| ID | Name |    | ID | user_id | Name      |
+----+------+    +----+---------+-----------+
| 1  | Bob  |    | 1  | 1       | Blargg... | 
+----+------+    +----+---------+-----------+
| 2  | Jim  |    | 2  | 1       | Blargg... | 
+----+------+    +----+---------+-----------+
| 3  | Jo   |    | 3  | 2       | Blargg... | 
+----+------+    +----+---------+-----------+

我尝试了以下SQL命令的许多变体,但没有任何成功。而不是显示单个用户的帖子数,它显示一行,所有帖子都作为计数。

SELECT users.* , COUNT( Posts.user_id ) 
FROM users
LEFT JOIN Posts ON users.id = Posts.user_id

最后我想要这样的东西

+----+------+ 
| ID | Count|
+----+------+
| 1  |  2   |  
+----+------+
| 2  |  1   |  
+----+------+

2 个答案:

答案 0 :(得分:8)

想出来。 自我抨击

SELECT users.*, count( posts.user_id ) 
FROM posts LEFT JOIN users ON users.id=posts.user_id 
GROUP BY posts.user_id

答案 1 :(得分:2)

select users.*, count(posts.user_id)

from users, posts
where users.user_id = posts.user_id
group by posts.user_id

但最好的方法是在users表中添加一个字段,并保留每个用户发布的帖子数量,并在创建或删除帖子时更新它。否则,当数据库变大时,你会放慢它的速度。