力扣数据库题库学习(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;
相关推荐
Ludicrouers8 分钟前
【Leetcode-Hot100】字母异位词分组
算法·leetcode·职场和发展
爱笑的Sunday8 分钟前
【LeetCode 题解】数据库:1321.餐馆营业额变化增长
数据库·sql·leetcode
程序员老周66612 分钟前
从MySQL快速上手大数据Hive
大数据·数据库·hive·hadoop·mysql·mapreduce·数据工程师
不辉放弃12 分钟前
第三章:SQL 高级功能与性能优化
服务器·前端·sql·mysql
纪元A梦16 分钟前
Redis最佳实践——搜索与分类缓存详解
数据库·redis·缓存
sensor_WU21 分钟前
SQLite 中日期型数据定义及处理(Delphi 版本)
数据库·sqlite
m0_6879146331 分钟前
mysql和sqlite关于data数据的识别问题
数据库·mysql·sqlite
敲键盘的小夜猫41 分钟前
热Key问题及其解决方案:Redis高并发场景下的性能优化
数据库·redis·性能优化
DXM05211 小时前
ArcGIS Engine开发教程--从零搭建GIS桌面应用
大数据·数据库·arcgis·c#·arcgis engine·arcgis engine开发
Bryce-Lin1 小时前
深度学习、图像算法学习记录
深度学习·学习·算法