力扣数据库题库学习(5.8日)--1795. 每个产品在不同商店的价格

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

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

示例 1:

输入:
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 无法买到。

思路分析

要求我们重构输出:

  1. 将旧表除了product_id的其他字段名作为新表store字段值
  2. 将旧表除了product_id的其他字段值,作为新表price字段值

这个表内就只有三个其他字段,我们可以直接暴力筛选store1、store2、store3的值作为price,然后将结果使用UNION ALL合并起来即可。

暴力的代码如下:

复制代码
SELECT product_id, 'store1' AS store, store1 AS price FROM Products WHERE store1 IS NOT NULL
UNION ALL
SELECT product_id, 'store2' AS store, store2 AS price FROM Products WHERE store2 IS NOT NULL
UNION ALL
SELECT product_id, 'store3' AS store, store3 AS price FROM Products WHERE store3 IS NOT NULL;
相关推荐
南無忘码至尊几秒前
Unity学习90天-第2天-认识键盘 / 鼠标输入(PC)并实现WASD 移动,鼠标控制物体转向
学习·unity·c#·游戏开发
HealthScience几秒前
clinvar数据集说明
数据库·oracle
sp_fyf_20243 分钟前
【大语言模型】OpenVLThinkerV2:面向多领域视觉任务的通用型多模态推理模型
人工智能·深度学习·学习·语言模型·transformer
王的宝库8 分钟前
【MySQL】主从复制原理详解:从 Binlog 到数据一致性
数据库·mysql
Vect__10 分钟前
MySQL基本认知、库和表的操作
数据库·mysql
wangwangmoon_light11 分钟前
1.23 LeetCode总结(树)_一般树
算法·leetcode·职场和发展
被考核重击13 分钟前
基础算法学习
学习·算法
creator_Li14 分钟前
Kafka 全面技术笔记
笔记·学习·kafka
楼田莉子16 分钟前
设计模式:构造器模式
开发语言·c++·后端·学习·设计模式
南境十里·墨染春水19 分钟前
linux学习进展 进程
linux·运维·学习