0

以下に参加したいテーブルが2つあります。テーブルの詳細は次のとおりです

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 に答える