特に難しいことではありません。
- JOIN句を使用して3つのテーブルを結合します。
- 関心のあるフィールドでGroup_concatを使用します。
- 連結していないフィールドまたは
奇妙なフィールドのGROUPBY句を忘れないでください物事が起こります
SELECT u.id,
u.Name,
Group_concat(us.id_sport order by pref) sport_ids,
Group_concat(s.name order by pref) sport_names
FROM users u
LEFT JOIN User_Sports us
ON u.id = us.id_user
LEFT JOIN sports s
ON US.id_sport = s.id
GROUP BY u.id,
u.Name
更新 コメントごとにユーザーがUser_Sportsにエントリを持っていない場合のLEFTJOIN