SQL按日期分组销售产品,使用group_concat和separator

题目来源:LeetCode

编写一个 SQL 查询来查找每个日期、销售的不同产品的数量及其名称。
每个日期的销售产品名称应按词典序排列,并用逗号隔开。
返回按 sell_date 排序的结果表。

1:题目分析

①根据”按 sell_date 排序的结果表“,以及”查找每个日期、销售的不同产品的数量及其名称“,可以判断出需要对sell_date进行分组与排序,同时需要计算每个销售不同产品的数量

SELECT sell_date, 
COUNT(DISTINCT product) AS num_sold,
product
FROM Activities
GROUP BY sell_date
ORDER BY sell_date;

②此时product结果只会显示日期首次出现的结果。根据题目:不同的销售产品名称应按词典序排列,并用逗号隔开,确定需要使用distinct和separator。
问题是如何将字段连接?
新学到group_concat,有点像Hive的CONCAT_WS(separator, str1, str2,…)

GROUP_CONCAT([DISTINCT] 要连接的字段 [ORDER BY ASC/DESC 排序字段] [SEPARATOR '分隔符'])

2:结果

SELECT sell_date, 
COUNT(DISTINCT product) AS num_sold, 
GROUP_CONCAT(DISTINCT product ORDER BY product separator ',') AS products
FROM Activities
GROUP BY sell_date
ORDER BY sell_date;

版权声明:本文为SYBYy6原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。