У меня есть таблица с player
-s в отношении многих ко многим со skill
-s
Цель состоит в том, чтобы перечислить игроков и их "топ-3 навыков" с помощью одного запроса.
create table player(
id int primary key
);
create table skill(
id int primary key,
title varchar(100)
);
create table player_skills (
id int primary key,
player_id int,
skill_id int,
value int
);
Query:
SELECT
p.id,
group_concat(s.title SEPARATOR ', ') as skills
FROM player p
LEFT JOIN player_skills ps ON ps.player_id = p.id
LEFT JOIN skill s ON s.id = ps.skill_id
WHERE ps.value > 2
-- skills limit 3 some how ...
group by p.id
order by s.id
-- expected result
-- player_ID, skills
-- 1 , 'one'
-- 2 , 'one'
-- 3 , 'two, three, four'
Как вы можете видеть в скрипте, в результате запроса не хватает только 3-х навыков.
Я попробовал несколько вариантов подзапросов.. присоединяется и так, но без эффекта.