练习(一):标量子查询、表子查询

本文介绍了一种通过SQL查询来分析2021年某电商平台销售数据的方法。主要包括:计算特定日期销量最高的前三名店铺;确定每家店铺全年销量达到80%的日期;以及计算每家店铺过去30天的历史销量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

已知表格:
daily_sales:2021年每日销量表,有date,shop_id,order_id三列
1)算出2021-12-01销量前3的shop_id、销量quantity、排名rank
2)求每shop_id达到全年销量80%的日期:shop_id、date_80p
3)求每天每shop_id的历史30天销量:date、shop_id、quantity_30d

      SELECT
         shop_id,
         COUNT(order_id) quantity,
         (@i:=@i+1) 'rank'
         from daily_sales,(SELECT @i:=0) AS t
         where date = '2021-12-01'
         group by shop_id order by COUNT(order_id) desc limit 3
select t1.shop_id,
       t1.date as date_80p
             from 
         (select date,
               shop_id,
               count(order_id) daily_quantity
            from daily_sales
            group by shop_id,date
            )t1
                left join 
        (select
               shop_id,
               count(order_id) full_quantity
            from daily_sales
            group by shop_id
            )t2
        on t1.shop_id=t2.shop_id
where t1.daily_quantity >= 0.8*t2.full_quantity
select 
    date,
    shop_id,
    (select count(1) from daily_sales where date>date_sub(d.date),interval 30 day) and date<=d.date
) quantity_30d
    from daily_sales d
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sinJack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值