gpt4 book ai didi

mysql - 如何在没有聚合函数的情况下按公共(public)值分组并获得所有不同的值

转载 作者:行者123 更新时间:2023-12-01 00:34:33 26 4
gpt4 key购买 nike

我知道这是一个比较常见的问题,我已经查看了所有发现的问题,但我真的不明白该怎么做。

如果我有一个存储客户姓名的表并为其提供唯一 ID,如下所示:

餐 table 顾客:

CustomerId   CustomerName
1 Borislav
2 Jegveni

我有另一个存储产品名称和唯一 ID 的表,与客户表相同,如下所示:

产品表:

ProductId   ProductName

1 Artificial Grass
2 Light Bulb
3 Welding Mask

最后我有一张表存储每个用户购买的产品,如下所示:

客户收购:

UserWhoBoughtId    ProductBoughtId
1 1
1 2
1 3

现在,我想选择每个客户以及他们购买的商品

. . .
SELECT * FROM customers
LEFT JOIN Acquisitions ON CustomerId = UserWhoBoughtId
LEFT JOIN Products ON ProductId = ProductBoughtId
. . .

据我正确理解,GROUP BY 通过按公共(public)值分组来工作,在这种情况下我们可以按 customerId 进行分组,但这会给出多行,因为产品不同,具有不同的值,所以在为了让每个用户只获得一行,您需要使用聚合函数来告诉组如何处理具有不同值的列。

不确定这是一个很好的例子,但基本上我的问题是,有没有一种方法可以按 customerId 分组,并且仍然在一个结果中从 Customers Acquisitions 中获得每个值?这样我就可以显示每个客户购买了什么?

最佳答案

使用group_concat()这将为每个客户提供 1 行,所有产品都在逗号分隔列表中:

SELECT c.CustomerId, c.CustomerName,
group_concat(p.ProductName) Products
FROM Customers c
LEFT JOIN Acquisitions a ON c.CustomerId = a.UserWhoBoughtId
LEFT JOIN Products p ON p.ProductId = a.ProductBoughtId
GROUP BY c.CustomerId, c.CustomerName

如果您不想重复产品,请使用:

group_concat(distinct p.ProductName)

参见 demo .
结果:

| CustomerId | CustomerName | Products                                 |
| ---------- | ------------ | ---------------------------------------- |
| 1 | Borislav | Artificial Grass,Light Bulb,Welding Mask |
| 2 | Jegveni | |

关于mysql - 如何在没有聚合函数的情况下按公共(public)值分组并获得所有不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58171896/

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