[1795]. 每个产品在不同商店的价格

1.题目

表:Products

±------------±--------+
| Column Name | Type |
±------------±--------+
| product_id | int |
| store1 | int |
| store2 | int |
| store3 | int |
±------------±--------+
这张表的主键是product_id(产品Id)。
每行存储了这一产品在不同商店store1, store2, store3的价格。
如果这一产品在商店里没有出售,则值将为null

请你重构 Products 表,查询每个产品在不同商店的价格,使得输出的格式变为(product_id, store, price) 。如果这一产品在商店里没有出售,则不输出这一行。输出结果表中的 顺序不作要求 。

2.示例:

输入:
Products table:
+------------+--------+--------+--------+
| product_id | store1 | store2 | store3 |
+------------+--------+--------+--------+
| 0          | 95     | 100    | 105    |
| 1          | 70     | null   | 80     |
+------------+--------+--------+--------+
输出:
+------------+--------+-------+
| product_id | store  | price |
+------------+--------+-------+
| 0          | store1 | 95    |
| 0          | store2 | 100   |
| 0          | store3 | 105   |
| 1          | store1 | 70    |
| 1          | store3 | 80    |
+------------+--------+-------+
解释:
产品0在store1,store2,store3的价格分别为95,100,105。
产品1在store1,store3的价格分别为70,80。在store2无法买到。

3.答案

注意: 价格为null的信息不用输出
这里只要三个商店,可以查询每个产品每个商店的数据信息拼接起来。

select product_id,'store1' store,store1 price from products 
where store1 is not null
union 
select product_id,'store2' store,store2 price from products 
where store2 is not null
union
select product_id,'store3' store,store3  price from products 
where store3 is not null;

将结果表转为原始表

注意这里用到了group by分组,select后面只能跟集函数或者分组属性。
所以 if(store=‘store1’,price,null) store1需要加上集函数,
sum(if(store=‘store1’,price,null)) store1 或者
max(if(store=‘store1’,price,null)) store1 或者
min(if(store=‘store1’,price,null)) store1都可以

SELECT 
  product_id,
 MAX(IF(store = 'store1', price, NULL)) 'store1',
 SUM(IF(store = 'store2', price, NULL)) 'store2',
 MIN(IF(store = 'store3', price, NULL)) 'store3' 
FROM
  Products1
GROUP BY product_id ;

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/rearrange-products-table

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值