gpt4 book ai didi

mysql - 如何在 MySQL 中创建 View 以将第二个表中的行组合为第一个中的 CSV 列

转载 作者:可可西里 更新时间:2023-11-01 08:05:22 24 4
gpt4 key购买 nike

我需要在 MySQL 中创建 VIEW,它可以以这样的方式组合两个表,即对于第一个表中的每一行,必须添加第二个表中的列,但是由于行数据必须格式化为多个字段,每个字段都有多个 CSV行。

我最初的方法是使用 MySQL VIEW,但我无法找到将第二个表中的多行数据显示为 View 表中的 CSV 单单元格数据的方法。

这里有一些例子:

1st table: gears
+------------+------------------------+-----------------+
| MainGearID | MainGearName | MainGearType |
+------------+------------------------+-----------------+
| 1 | Main Drive | Spur |
| 2 | Secondary Drive | Spur |
| 3 | Backup Secondary Drive | Hypoid |
| 4 | AUX Drive | Rack and pinion |
+------------+------------------------+-----------------+

2nd table: orbitinggears:
+----------+------------+--------------+--------------+
| OrbitaID | MainGearID | OrbitalType | OrbitalValue |
+----------+------------+--------------+--------------+
| 1 | 1 | Spur | 112 |
| 2 | 1 | Spur | 280 |
| 3 | 2 | Spur | 144 |
| 4 | 2 | Spur | 248 |
| 5 | 3 | Helical | 18 |
| 6 | 4 | Spur | 144 |
+----------+------------+--------------+--------------+

Required View:
+------------+------------------------+-----------------+----------+---------+
| MainGearID | MainGearName | MainGearType | Spur | Helical |
+------------+------------------------+-----------------+----------+---------+
| 1 | Main Drive | Spur | 112,280, | |
| 2 | Secondary Drive | Spur | 144,248, | |
| 3 | Backup Secondary Drive | Hypoid | | 18, |
| 4 | AUX Drive | Rack and pinion | 144, | |
+------------+------------------------+-----------------+----------+---------+

有人知道如何以这种方式创建 View 吗?

最佳答案

您可以将 GROUP_CONCATIF() 一起使用:

CREATE VIEW v6 AS 
SELECT a.MainGearID, a.MainGearName, a.MainGearType,
GROUP_CONCAT(IF(b.OrbitalType='Spur',b.OrbitalValue,null)) AS Spur,
GROUP_CONCAT(IF(b.OrbitalType='Helical',b.OrbitalValue,null)) AS Helical
FROM gears a
JOIN orbitinggears b on b.MainGearID=a.MainGearID
GROUP BY a.MainGearID;

关于mysql - 如何在 MySQL 中创建 View 以将第二个表中的行组合为第一个中的 CSV 列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31604614/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com