题目来源: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;
|