0

我有两个要加入的表格,下面是表格的详细信息

Trophy_lookup表包含

id | user_id | trophy_id
1  | 2       | 2
2  | 3       | 4
3  | 1       | 5
4  | 2       | 1
4  | 1       | 1

Users表包含一般用户信息

id | name    | email
1  | john    | john@webcom
2  | jacky   | jacky@web.com
3  | Smith   | smith@web.com
4  | Rob     | rob@web.com

问题 我想以一种我可以计算用户赢得多少奖杯以及用户名的方式加入users表格trophy_lookup下面是我想要实现的所需输出。

user_id| name | count(trophis)
     1 | john | 2
     2 | jacky| 2

到目前为止,我已经尝试了很多东西,但我无法达到上述结果。我不擅长写查询,所以请指导我。谢谢

4

2 回答 2

2

试试这个查询

select a.id, a.name, count(*) as cnt
from table2 a 
inner join 
table1 b
on a.id = b.user_id
group by 
a.id, a.name
having count(*) > 1
order by cnt

SQL 小提琴

| ID |  NAME | CNT |
--------------------
|  2 | jacky |   2 |
|  1 |  john |   2 |

替代方法

select a.name, b.* 
from table2 a
inner join 
(select a.id, count(*) as cnt
from table2 a 
inner join 
table1 b
on a.id = b.user_id
group by 
a.id) b 
ON a.id=b.id
where cnt > 1

SQL 小提琴

|  NAME | ID | CNT |
--------------------
|  john |  1 |   2 |
| jacky |  2 |   2 |
于 2013-05-17T09:24:30.580 回答
0

试试这个查询:

SELECT u.id,count(u.id),u.name 
FROM trophy_lookup t 
JOIN users u ON t.user_id=u.id 
GROUP BY u.id ;
于 2013-05-17T09:34:00.163 回答