首页 > 数据库 > mysql教程 > 如何使用 JOIN 将三个 MySQL 表中的数据合并到一个新表中?

如何使用 JOIN 将三个 MySQL 表中的数据合并到一个新表中?

Linda Hamilton
发布: 2024-12-05 21:32:11
原创
481 人浏览过

How to Combine Data from Three MySQL Tables into a New Table Using JOINs?

使用 MySQL 将多个表中的数据组合到一个新表中

在使用关系数据库时,经常需要组合多个表中的数据到一个新表中。本问题演示了如何在 MySQL 中使用 3 路 JOIN 来实现此目的。

目标: 创建一个新表,其中包含三个现有表(人员、分类法和详情)。

现有表:

people
id  last_name  first_name  email
1   Smith       Fred        Fred@..
2   Jones       Tom         Tom@..
3   Doe         Jane        Jane@..

taxonomy
id  taxonomy    
1   age
2   gender
3   height

details
id  person_id   detail_id   content
1   1           1           36
2   1           2           M
3   1           3           5'10"
4   2           1           29
5   2           2           M
6   2           3           6'3"
7   3           1           27
8   3           2           F
9   3           3           5'8"
登录后复制

所需结果(新表):

id  last_name  first_name  email   age
1   Smith       Fred        Fred@.. 36
2   Jones       Tom         Tom@..  29
3   Doe         Jane        Jane@.. 27
登录后复制

使用 3 向 JOIN 的解决方案:

要创建新表,我们需要执行3路JOIN根据公共值连接三个现有表:

CREATE TABLE new_table AS
SELECT p.*, d.content AS age
FROM people AS p
JOIN details AS d ON d.person_id = p.id
JOIN taxonomy AS t ON t.id = d.detail_id
WHERE t.taxonomy = 'age';
登录后复制

此JOIN根据person_id列将people表中的数据与details表中的数据结合起来,然后进一步联接details表使用基于detail_id列的分类表,仅过滤分类为“年龄”的行。

备用方法(针对多个属性):

要包含详细信息表中的多个属性(例如年龄、性别和身高),您需要为每个属性执行单独的 JOIN:

CREATE TABLE new_table AS
SELECT p.*, d1.content AS age, d2.content AS gender, d3.content AS height
FROM people AS p
JOIN details AS d1 ON d1.person_id = p.id
JOIN taxonomy AS t1 ON t1.id = d1.detail_id
JOIN details AS d2 ON d2.person_id = p.id
JOIN taxonomy AS t2 ON t2.id = d2.detail_id
JOIN details AS d3 ON d3.person_id = p.id
JOIN taxonomy AS t3 ON t3.id = d3.detail_id
WHERE t1.taxonomy = 'age' AND t2.taxonomy = 'gender' AND t3.taxonomy = 'height';
登录后复制

这种方法允许您将详细信息表中多列的数据合并到新表中。

以上是如何使用 JOIN 将三个 MySQL 表中的数据合并到一个新表中?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板