MySQL从3个表中选择所有不同数量的行

标签 mysql left-join inner-join

我想检索所有成员和所有成员船的列表。 我这样做的方式是获取成员拥有的每艘船的成员信息。因此,如果成员 John Smith 有 3 艘船,则 John Smith 将显示 3 次。 我希望名称和信息只显示一次,并且空列而不是与船一起显示。

SELECT m.memberId, m.fName, m.lName, m.ssn, b.boatId, b.length, bt.type
FROM member AS m
RIGHT JOIN boat AS b
ON m.memberId = b.memberId
INNER JOIN boatType AS bt
ON b.boatTypeId = bt.boatTypeId

最佳答案

正如 Joe 所建议的,您可以像这样在 MySQL 中使用 GROUP_CONCAT 和 CONCAT 函数。

   SELECT m.memberId, m.fName, m.lName, m.ssn, 
          GROUP_CONCAT(CONCAT(b.boatId, '(', bt.type, ':',b.length,' ft.)')
                       ORDER BY bt.boatId SEPARATOR '; ')
     FROM member AS m
LEFT JOIN boat AS b ON m.memberId = b.memberId
     JOIN boatType AS bt ON b.boatTypeId = bt.boatTypeId
 GROUP BY m.memberId, m.fName, m.lName, m.ssn

这会给你这样的行。

1 Larry Ellison 123-45-6789 USA 17(Americas Cup:113 ft.); Rising Sun(Diesel:453 ft.)
2 Ollie Jones 987-65-4321 Scruffy Guppy(Sunfish:12 ft.)

关于MySQL从3个表中选择所有不同数量的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12962339/

相关文章:

mysql - 连续非空值的计数

php - 我将如何加密我的 php 文件,以便只有拥有 key 的人才能访问它们?

mysql - 左连接坏了?

mysql - 按大小写忽略 LEFT JOIN 查询中的多条记录

mysql - 外部和内部 SQL 连接

mysql - SQL 获取多年平均销售成本

python - 从 Jupyter Notebook 连接到 MySQL 数据库

mysql - 'parent.username' 中的未知列 'field list' 在 2 个表上执行 LEFT JOIN

mysql - 在 SQL 中连接多个表

mysql - 使用连接根据 MySQL 上的日期更新记录