[英]Pivoting a table in MySQL
我在最近的一次采访中得到了这个问题。 我的 SQL 生锈了,我什至不知道从哪里开始。
这是提供的表格
-----------------------------------
date product quantity_sold
-----------------------------------
12/3/2019 A 200
-----------------------------------
11/6/2019 B 200
-----------------------------------
12/7/2019 B 200
-----------------------------------
10/1/2019 C 200
-----------------------------------
12/9/2019 D 200
-----------------------------------
如果只有 3 个产品 A、B 和 C 按以下格式显示数据
date product_A_quantity_sold product_A_quantity_sold product_A_quantity_sold
您需要条件聚合:
select date,
max(case when product = 'A' then quantity_sold end) product_A_quantity_sold,
max(case when product = 'B' then quantity_sold end) product_B_quantity_sold,
max(case when product = 'C' then quantity_sold end) product_C_quantity_sold
from tablename
group by date
如果您想在某个日期未售出产品时看到0
而不是NULL
,则在每个CASE
表达式中添加一个ELSE
部分,例如:
max(case when product = 'A' then quantity_sold else 0 end) product_A_quantity_sold
对于 MySql,您也可以使用以下代码:
select date,
max((product = 'A') * quantity_sold) product_A_quantity_sold,
max((product = 'B') * quantity_sold) product_B_quantity_sold,
max((product = 'C') * quantity_sold) product_C_quantity_sold
from tablename
group by date
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.