mysql pivot 语法_MySQL pivot row成动态列数

MySQL pivot row成动态列数

可以说我有三个不同的MySQL表:

表products:

id | name

1   Product A

2   Product B

表partners:

id | name

1   Partner A

2   Partner B

表sales:

partners_id | products_id

1             2

2             5

1             5

1             3

1             4

1             5

2             2

2             4

2             3

1             1

我想得到一个表格,其中包含行和产品中的合作伙伴作为列。到目前为止,我能够得到这样的输出:

name      | name      | COUNT( * )

Partner A   Product A          1

Partner A   Product B          1

Partner A   Product C          1

Partner A   Product D          1

Partner A   Product E          2

Partner B   Product B          1

Partner B   Product C          1

Partner B   Product D          1

Partner B   Product E          1

使用此查询:

SELECT partners.name, products.name, COUNT( * )

FROM sales

JOIN products ON sales.products_id = products.id

JOIN partners ON sales.partners_id = partners.id

GROUP BY sales.partners_id, sales.products_id

LIMIT 0 , 30

但我希望有类似的东西:

partner_name | Product A | Product B | Product C | Product D | Product E

Partner A              1           1           1           1           2

Partner B              0           1           1           1           1

问题是,我不知道我将拥有多少产品,因此列号需要根据products表中的行动态更改。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值