首页 >数据库 >mysql教程 >如何在 SQL 中连接具有逗号分隔值的表?

如何在 SQL 中连接具有逗号分隔值的表?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-14 04:32:141041浏览

How to Join Tables with Comma-Separated Values in SQL?

用逗号分隔值连接两个表

问题:

我们有两个表:注释和立场。 Notes 表包含一个名为“forDepts”的列,用于存储以逗号分隔的部门 ID。我们需要连接这些表,并将“forDepts”值与 Positions 表中相应的部门名称相关联。

所需输出:

nid DepartmentName
1 Executive, Corp Admin, Art
2 Art, Marketing

解决方案:

由于数据库结构无法修改,所以我们将使用以下SQL查询以获得所需的输出:

SELECT  a.nid,
        GROUP_CONCAT(b.name ORDER BY b.id) DepartmentName
FROM    Notes a
        INNER JOIN Positions b
            ON FIND_IN_SET(b.id, a.forDepts) > 0
GROUP   BY a.nid

解释:

  • GROUP_CONCAT 函数用于连接 Positions 表中的“name”列值对于 Notes 表中的每一行。
  • ORDER BY 子句确保部门名称有序
  • FIND_IN_SET 函数检查 Positions 表中的部门 ID 是否存在于 Notes 表的“forDepts”列中。如果是,则相应的行将包含在联接中。
  • GROUP BY 子句按 Notes 表中的“nid”列对结果进行分组,有效组合与每个注释关联的所有部门名称。

通过执行此查询,我们可以获得所需的输出,其中 Notes 表中的 'forDepts' 列值被替换为相应的以逗号分隔的部门名称从职位表中。这将有助于使用提供的 PHP 代码将数据导出到 Excel 文件中。

以上是如何在 SQL 中连接具有逗号分隔值的表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn