【SQL思考记录】力扣1821. 寻找今年具有正收入的客户

SQL解题分析与代码解读

题目背景

本题目要求我们从Customers表中查询2021年具有正收入的客户。Customers表包含了客户ID、年份和收入三个字段,其中(customer_id, year)组合作为表的主键,保证了唯一性。需要注意的是,客户的收入可能为负数。

题目要求

  • 查询2021年收入为正数的客户ID。
  • 结果可以按任意顺序返回。

解决方案分析

方案一

SELECT 
    customer_id
FROM 
    Customers
WHERE
    revenue > 0 AND year = 2021
;

解释

  1. 选择字段:本查询选择了customer_id字段。
  2. 条件筛选
    • WHERE子句用于筛选数据。
    • revenue > 0确保只选取收入为正的记录。
    • year = 2021确保选取的是2021年的数据。
  3. 结果:此查询返回所有在2021年有正收入的客户ID。

方案二

SELECT 
    customer_id
FROM 
    Customers
WHERE
    year = 2021
GROUP BY customer_id, year
HAVING 
    sum(revenue) > 0
;

解释

  1. 选择字段:选取customer_id字段。
  2. 条件筛选
    • WHERE子句筛选2021年的记录。
    • GROUP BY customer_id, year将数据按客户ID和年份分组。
  3. 分组聚合
    • HAVING sum(revenue) > 0是对分组后的数据进行过滤。
    • sum(revenue)计算每个分组(即每个客户在2021年的)总收入。
    • 只选择总收入为正的客户ID。
  4. 结果:此查询返回所有在2021年总收入为正的客户ID。

结论

两种方案都能有效解决问题,但在处理数据时略有不同。第一种方法直接筛选出2021年收入为正的记录,而第二种方法则是先按客户ID和年份分组,再计算每个分组的总收入,最后筛选出总收入为正的客户ID。选择哪种方法取决于具体的数据情况和性能考虑。


  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值