温馨提示×

mysql怎么多行合并一行

小亿
97
2024-08-17 12:05:35
栏目: 云计算

在MySQL中,可以使用GROUP BY和聚合函数来合并多行数据为一行数据。以下是一个示例:

假设有一个名为orders的表,包含以下示例数据:

order_id customer_id product_id quantity
1 101 1 2
2 101 2 3
3 102 1 1
4 102 3 4

如果要将customer_id相同的记录合并为一行,可以使用以下查询:

SELECT customer_id, GROUP_CONCAT(CONCAT(product_id, ':', quantity) SEPARATOR ', ') AS products
FROM orders
GROUP BY customer_id;

这将返回以下结果:

customer_id products
101 1:2, 2:3
102 1:1, 3:4

在这个例子中,我们使用GROUP_CONCAT函数将每个customer_id的产品和数量组合成一个字符串,并用逗号分隔不同的产品。

0