首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在一行中获取一对多关系中的所有值

在一行中获取一对多关系中的所有值
EN

Stack Overflow用户
提问于 2013-02-25 21:12:21
回答 3查看 4.7K关注 0票数 2

我的数据库中有一个一对多的关系。

我想获取所有的城市与所有的影院附加在一行作为CSV。我试过了:

代码语言:javascript
运行
复制
SELECT city.*,CONCAT(cinema_name)
FROM city
LEFT JOIN cinema
ON cinema.city_id=city.city_id
GROUP BY city.city_id

但这只会返回第一家影院。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-02-25 21:13:37

使用GROUP_CONCAT而不是CONCAT

代码语言:javascript
运行
复制
SELECT
  city.*,
  GROUP_CONCAT(cinema_name) AS `Cinemas`
FROM city
  LEFT JOIN cinema
    ON cinema.city_id = city.city_id
GROUP BY city.city_id
票数 16
EN

Stack Overflow用户

发布于 2013-02-25 21:14:53

尝试此查询

代码语言:javascript
运行
复制
SELECT ct.city_id, GROUP_CONCAT(cinema_name) 
FROM cinema c, city ct
WHERE c.city_id = ct.city_id
Group BY c.city_id;
票数 1
EN

Stack Overflow用户

发布于 2018-06-19 13:36:41

对于在MySQLV5.7上测试的当前版本的,如果希望将数据作为json对象,可以尝试这样做。

代码语言:javascript
运行
复制
SELECT
  city.*,
  GROUP_CONCAT(
JSON_OBJECT(
'cinema_name', cinema_name
)) AS `Cinemas`
FROM city
  LEFT JOIN cinema
    ON cinema.city_id = city.city_id
GROUP BY city.city_id
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15067808

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档