3

MySQL データベースに 3 つの異なるテーブルがあります。

テーブル users: (id, score, name)テーブル team:
(id, title)
テーブル team_Members: (team_id, user_id)

私がやりたいことは、特定のユーザー ID がメンバーであるすべてのチーム ID を検索する 1 つのクエリと、次の情報を用意することです。

  1. そのチームのメンバーの総数
  2. チームの名前
  3. チーム内のユーザーのランク (スコアに基づく)

編集:

目的の出力は次のようになります。

TITLE (of the group)      NUM_MEMBERS       RANK
------------------------------------------------
Foo bar team              5                 2
Another great group       34                17
.
.
.

クエリは、ユーザー ID に基づいている必要があります。

助けていただければ幸いです

4

2 に答える 2

1

このクエリはあなたが求めるものを取得するはずだと思います

select t.id, t.title, count(m.user_id) members, (
    select count(1)
    from users u3 
    inner join team_Members m3 on u3.id = m3.user_id 
    and m3.team_id = t.id and u3.score > (
        select score from users where name = 'Johan'
    )
) + 1 score
from teams t
inner join team_Members m on t.id = m.team_id
where t.id in (
    select team_id 
    from team_Members m2
    inner join users u2 on m2.user_id = u2.id
    where u2.name = 'Johan'
)
group by t.id, t.title
于 2012-07-12T22:46:21.203 に答える
0

収集するには、JOINを使用するだけです

SELECT 
  u.*, t.*, tm.* 
FROM 
  users u 
JOIN 
  team_Members tm ON  u.id = tm.user_id 
JOIN 
  teams t ON t.id = tm.team_id;

そのチームの合計数を取得するには、いくつかのグループキーで COUNT を使用します

そのようないくつか

SELECT 
  COUNT(t.id), u.*, t.*, tm.* 
FROM 
  users u 
JOIN 
  team_Members tm ON u.id = tm.user_id 
JOIN 
  teams t ON t.id = tm.team_id GROUP BY t.id;

そして、ランク付けするには:

SELECT 
  COUNT(t.id) as number_of_members, u.*, t.*, tm.* 
FROM 
  users u 
JOIN 
  team_Members tm ON u.id = tm.user_id 
JOIN 
  teams t ON t.id = tm.team_id 
GROUP BY t.id 
ORDER BY u.score;
于 2012-07-12T22:43:15.287 に答える