微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MySQL:将联接后的多个值合并到一个结果列中

如何解决MySQL:将联接后的多个值合并到一个结果列中

您需要对SELECT中的所有非聚合列进行分组(并且明确地,不按作者ID分组,因为author是GROUP_CONCAT的一部分):

SELECT p.`id`, p.`title`, GROUP_CONCAT(a.`fullname` separator ', ')
from `publications` p 
LEFT JOIN `authors` a on a.`publication_id` = p.`id` 
GROUP BY p.`id`, p.`title`;

解决方法

我有一个带有用于发布的表的数据库,每个表可以有多个作者,这些作者存储在不同的表中。我想查询数据库,以便在第一列中提供出版物标题列表,在第二列中提供该出版物的合并作者。

SELECT p.`id`,p.`title`,a.`fullname` 
from `publications` p 
LEFT JOIN `authors` a on a.`publication_id` = p.`id`;

当然,这使我多次获得了许多作者的出版物标题。

id   title              fullname
--   -----              --------
1    Beneath the Skin   Sean French
1    Beneath the Skin   Nicci Gerrard
2    The Talisman       Stephen King
2    The Talisman       Peter Straub

按ID分组后,每个标题给我一个作者:

SELECT p.`id`,a.`fullname` 
from `publications` p 
LEFT JOIN `authors` a on a.`publication_id` = p.`id` 
GROUP BY a.`id`;

id   title              fullname
--   -----              --------
1    Beneath the Skin   Sean French
2    The Talisman       Stephen King

我正在寻找的结果是这样的:

id   title              fullname
--   -----              --------
1    Beneath the Skin   Sean French,Nicci Gerrard
2    The Talisman       Stephen King,Peter Straub

我认为应该在使用GROUP_CONCAT中找到答案,但是我唯一能得到的结果是所有作者的一个结果行:

SELECT p.`id`,GROUP_CONCAT(a.`fullname`) from `publications` p 
LEFT JOIN `authors` a on a.`publication_id` = p.`id` 
GROUP BY a.`id`;

id   title              fullname
--   -----              --------
1    Beneath the Skin   Sean French,Nicci Gerrard,Stephen King,Peter Straub

在联接之后使用GROUP_CONCAT会给我一个“每个派生表必须具有自己的别名”的错误。

SELECT p.`id`,a.`fullname` 
FROM `publications` p 
LEFT JOIN (SELECT GROUP_CONCAT(a.`fullname`) FROM `authors` a) ON a.`publication_id` = p.`id`;

有什么线索吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。