在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的产品和数量组合成一个字符串,并用逗号分隔不同的产品。