繁体   English   中英

"MySQL将行转换为动态列数"

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM