美文网首页
Leetcode1485. 按日期分组销售产品(简单)

Leetcode1485. 按日期分组销售产品(简单)

作者: kaka22 | 来源:发表于2020-07-23 14:38 被阅读0次

    题目
    表 Activities:

    +-------------+---------+
    | 列名         | 类型    |
    +-------------+---------+
    | sell_date   | date    |
    | product     | varchar |
    +-------------+---------+
    

    此表没有主键,它可能包含重复项。
    此表的每一行都包含产品名称和在市场上销售的日期。

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

    查询结果格式如下例所示。

    Activities 表:

    +------------+-------------+
    | sell_date  | product     |
    +------------+-------------+
    | 2020-05-30 | Headphone   |
    | 2020-06-01 | Pencil      |
    | 2020-06-02 | Mask        |
    | 2020-05-30 | Basketball  |
    | 2020-06-01 | Bible       |
    | 2020-06-02 | Mask        |
    | 2020-05-30 | T-Shirt     |
    +------------+-------------+
    

    Result 表:

    +------------+----------+------------------------------+
    | sell_date  | num_sold | products                     |
    +------------+----------+------------------------------+
    | 2020-05-30 | 3        | Basketball,Headphone,T-shirt |
    | 2020-06-01 | 2        | Bible,Pencil                 |
    | 2020-06-02 | 1        | Mask                         |
    +------------+----------+------------------------------+
    

    对于2020-05-30,出售的物品是 (Headphone, Basketball, T-shirt),
    按词典序排列,并用逗号 ',' 分隔。
    对于2020-06-01,出售的物品是 (Pencil, Bible),按词典序排列,并用逗号分隔。
    对于2020-06-02,出售的物品是 (Mask),只需返回该物品名。

    解答
    每个日期、销售的不同产品的数量及其名称。
    数量是很好统计的 但是名称连接起来 能想到的只有concat 但用起来太麻烦了。。
    MySQL 的 GROUP_CONCAT 函数详解

    select A. sell_date, count(distinct A.product) as num_sold,
    group_concat(distinct A.product order by A.product separator ',') as products 
    from Activities as A
    group by A.sell_date
    

    相关文章

      网友评论

          本文标题:Leetcode1485. 按日期分组销售产品(简单)

          本文链接:https://www.haomeiwen.com/subject/vdeclktx.html