gpt4 book ai didi

mysql - GROUP_CONCAT 有限制

转载 作者:IT老高 更新时间:2023-10-28 12:58:17 26 4
gpt4 key购买 nike

我与 player-s 有一个与 skill-s

多对多关系的表格

目标是通过单个查询列出玩家及其“前 3 项技能”。

fiddle

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
);

查询:

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'

正如您在 fiddle 中看到的那样,查询结果仅缺少 3 个技能的限制。
我尝试了几种子查询的变体.. 连接等等,但没有任何效果。

最佳答案

一种有点老套的方法是对 GROUP_CONCAT 的结果进行后处理:

substring_index(group_concat(s.title SEPARATOR ','), ',', 3) as skills

当然,这假设您的技能名称不包含逗号,并且它们的数量相当小。

fiddle

一个 feature request遗憾的是,GROUP_CONCAT 支持显式 LIMIT 子句仍未解决。

更新:作为用户 Strawberry指出,表 player_skills 应该将元组 (player_id, Skill_id) 作为其主键,否则该模式允许将相同的技能多次分配给玩家,在这种情况下 group_concat 将无法按预期工作。

关于mysql - GROUP_CONCAT 有限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23608464/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com