mysql之GROUP_CONCAT

1484. 按日期分组销售产品

表 Activities:
±------------±--------+
| 列名 | 类型 |
±------------±--------+
| sell_date | date |
| product | varchar |
±------------±--------+
此表没有主键,它可能包含重复项。
此表的每一行都包含产品名称和在市场上销售的日期。
编写一个 SQL 查询来查找每个日期、销售的不同产品的数量及其名称。
每个日期的销售产品名称应按词典序排列。
返回按 sell_date 排序的结果表。
查询结果格式如下例所示。
±-----------±---------±-----------------------------+
| sell_date | num_sold | products |
±-----------±---------±-----------------------------+
| 2020-05-30 | 3 | Basketball,Headphone,T-shirt |
| 2020-06-01 | 2 | Bible,Pencil |
| 2020-06-02 | 1 | Mask |
±-----------±---------±-----------------------------+

问题分析

难点:需要将查询出来的products使用’,'进行拼接
开始计划使用CONCAT_WS(symbol, str2, str3……)进行拼接,但是该函数需要使用已知的字段进行拼接,而本题使用的是查询的多行结果拼接

select 
    sell_date, 
    COUNT(distinct product ) as num_sold,
    CONCAT_WS(',' , select product from Activities as b where b.sell_date = sell_date) as products
from 
    Activities  as a
group by 
    sell_date
order by 
    sell_date;

报错

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘select product from Activities as b where b.sell_date = sell_date) as products
f’ at line 5

搜寻一番发现了GROUP_CONCAT函数

GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASC\DESC] [SEPARATOR seq]);
  • DISTINCT 是可选,去重
  • column1 需要拼接的列
  • [ORDER BY column2 ASC\DESC] 可选 是否需要排序
  • [SEPARATOR seq] 拼接符 可选 如果没有指定SEPARATOR的话,也就是说没有写,那么就会默认以 ','分隔

代码:

# Write your MySQL query statement below
select 
    sell_date, 
    COUNT(distinct product ) as num_sold,
    GROUP_CONCAT(distinct product order by product SEPARATOR ',') products
from 
    Activities  as a
group by 
    sell_date
order by 
    sell_date;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值