如何在 MySQL 中将多行合并为单个逗号分隔行?

Patricia Arquette
发布: 2024-11-08 12:21:02
原创
674 人浏览过

How to Combine Multiple Rows into a Single Comma-Separated Row in MySQL?

MySQL:将多行转换为单个逗号分隔行

在 MySQL 数据库中,您可能会遇到这样的情况:将多行压缩为一行,特定列表示为逗号分隔值。这可以通过利用 GROUP_CONCAT 函数来实现,如以下示例场景所示。

示例场景:

考虑两个表:DISH 和 DISH_HAS_DISHES,其中 DISH 保存所有可用的菜肴,DISH_HAS_DISHES 定义 DISH 之间的一对多关系。 DISH 表具有以下结构:

而 DISH_HAS_DISHES 表如下所示:

目标:

我们的目标是将数据转换为每顿饭都有相应行的格式,以逗号分隔值列出其菜肴 ID 和名称。所需的输出是:

解决方案:

为了实现这一点,我们将使用 GROUP_CONCAT 函数以及一些简单的 JOIN 操作:

在此查询中:

  • 我们首先将 DISH_HAS_DISHES 表 (m) 与 DISH 表 (d) 的 Dish_id 列连接起来。
  • 在 SELECT 语句内,我们使用 GROUP_CONCAT 来合并菜肴 ID 和菜肴名称 列中的多个值。
  • 最后,我们按 Meal_id 对结果进行分组,以获得每顿饭的单行。

通过执行通过此查询,我们将获得所需的输出,其中每一行代表一顿饭、其菜肴 ID 及其相应的菜肴名称,所有这些都表示为逗号分隔值。当处理表格数据和跨多行合并信息时,此技术特别有用。

以上是如何在 MySQL 中将多行合并为单个逗号分隔行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!