我正在开发一个迷你项目来学习一些SQL。我目前在将多行组合成列时遇到了一些困难。Oracle - 通过左连接将多个行组合到列
我试图清理表是
GroupID Product Attribute1 Attribute 2 100 1 blue red 100 2 gold blue 101 1 pink blue 101 2 black white 101 3 purple grey
我试图生产是唯一独特的组ID的一个表,所以:
Group ID Product1 pr1Attribute 1 pr1Attribute2 Product2 pr2Attribute1 pr2Attribute2 Product3 pr3Attribute1 pr3Attribute2
行数据:
100 1 blue red 2 gold blue null null null 101 1 pink blue 2 black white 3 purple grey
我试过以下
select distinct full.groupid, product1.product as product1,
product1.attr1 as product1_attrib1, product1.attr2 as product1_attrib2,
product2.product as product2, product2.attr1 product2_attribute1,
product2.attr2 product2_attribute2, product3.product as product3,
product3.attr1 as product3_attrib1, product3.attr2 as product1_attrib2
from tabletest full
left join tabletest product1 on (full.groupid = product1.groupid and product1.producttem = '1')
left join tabletest product2 on (full.groupid = product1.groupid and product2.producttem = '2')
left join tabletest product3 on (full.groupid = product1.groupid and product3.producttem = '3');
查询无法正常工作。它似乎没有考虑到AND
或以某种方式重复。
任何指导将不胜感激。我还想知道是否有一种实现这种方式的方式,以至于我不知道任何产品编号(因此基本上我不需要对它们进行硬编码)。
您要搜索的词是:PIVOT。有比三重自联接更有效的方法。 –