[英]MySQL pivot row into dynamic number of columns
假设我有三个不同的 MySQL 表:
餐桌
products<\/code> :<\/strong>
id | name
1 Product A
2 Product B
不幸的是 MySQL 没有
PIVOT<\/code>函数,这基本上是你想要做的。
因此,您需要使用带有
CASE<\/code>语句的聚合函数:
select pt.partner_name,
count(case when pd.product_name = 'Product A' THEN 1 END) ProductA,
count(case when pd.product_name = 'Product B' THEN 1 END) ProductB,
count(case when pd.product_name = 'Product C' THEN 1 END) ProductC,
count(case when pd.product_name = 'Product D' THEN 1 END) ProductD,
count(case when pd.product_name = 'Product E' THEN 1 END) ProductE
from partners pt
left join sales s
on pt.part_id = s.partner_id
left join products pd
on s.product_id = pd.prod_id
group by pt.partner_name
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.