【MySQL】语法 sum(条件表达式) 的巧用

2024-01-02 11:32:53

力扣题

1、题目地址

1083. 销售分析 II

2、模拟表

表:Product

Column NameType
product_idint
product_namevarchar
unit_priceint
  • Product_id 是该表的主键(具有唯一值的列)。
  • 该表的每一行表示每种产品的名称和价格。

表:Sales

Column NameType
seller_idint
product_idint
buyer_idint
sale_datedate
quantityint
priceint
  • 这个表可能有重复的行。
  • product_id 是 Product 表的外键(reference 列)。
  • buyer_id 永远不会是 NULL。
  • sale_date 永远不会是 NULL。
  • 该表的每一行都包含一次销售的一些信息。

3、要求

编写一个解决方案,报告那些买了 S8 而没有买 iPhone 的 买家。注意,S8 和 iPhone 是 Product 表中显示的产品。

以 任意顺序 返回结果表。

结果格式如下所示。

示例 1:

输入:
Product 表:

product_idproduct_nameunit_price
1S81000
2G4800
3iPhone1400

Sales 表:

seller_idproduct_idbuyer_idsale_datequantityprice
1112019-01-2122000
1222019-02-171800
2132019-06-021800
3332019-05-1322800

输出:

buyer_id
1

解释:
id 为 1 的买家购买了一部 S8,但是却没有购买 iPhone,而 id 为 3 的买家却同时购买了这 2 部手机。

4、代码编写

我的写法

思路是将买 S8 的买家先查询出来,再把买 iPhone 的人排除掉

SELECT DISTINCT(buyer_id)
FROM (
    SELECT a.buyer_id
    FROM Sales a
    LEFT JOIN Product b ON a.product_id = b.product_id
    WHERE b.product_name = 'S8'
) AS one
WHERE NOT EXISTS (
    SELECT a.* 
    FROM Sales a
    LEFT JOIN Product b ON a.product_id = b.product_id
    WHERE a.buyer_id = one.buyer_id 
    AND b.product_name = 'iPhone'
)

网友写法

用 sum 判断等式,符合值为1,不符合为0,很巧妙

SELECT b.buyer_id
FROM Product a, Sales b
WHERE a.product_id = b.product_id
GROUP BY b.buyer_id
HAVING SUM(a.product_name = 'S8') > 0 AND SUM(a.product_name = 'iPhone') = 0

知识点

可参考我之前写的文章:【MySQL】sum 函数和 count 函数的相同作用

文章来源:https://blog.csdn.net/weixin_50223520/article/details/135335191
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。