leetcode刷题MySQL题解十三

Posted hhh江月

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode刷题MySQL题解十三相关的知识,希望对你有一定的参考价值。

leetcode刷题mysql题解十三

题目叙述

表: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) 。如果这一产品在商店里没有出售,则不输出这一行。

输出结果表中的 顺序不作要求 。

查询输出格式请参考下面示例。

示例 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无法买到。

题目解答

# Write your MySQL query statement below
select product_id, 'store1' store, store1 as price
from Products
where store1 is not null
union all
select product_id, 'store2' store, store2 as price
from Products
where store2 is not null
union all
select product_id, 'store3' store, store3 as price
from Products
where store3 is not null;



题目运行

以上是关于leetcode刷题MySQL题解十三的主要内容,如果未能解决你的问题,请参考以下文章

leetcode刷题MySQL题解二十三

leetcode刷题MySQL题解十二

leetcode刷题MySQL题解十

leetcode刷题MySQL题解十

leetcode刷题MySQL题解一

leetcode刷题MySQL题解二