sql >> Base de Datos >  >> RDS >> Oracle

Transposición inconsistente

Podría usar una expresión de tabla común para dar a cada comprador un pedido dentro del proveedor y luego hacer un caso normal para ponerlos en columnas;

WITH cte AS (
  SELECT supplier, buyer, 
    ROW_NUMBER() OVER (PARTITION BY supplier ORDER BY buyer) rn
  FROM Table1
)
SELECT supplier, 
       MAX(CASE WHEN rn=1 THEN buyer END) buyer1,
       MAX(CASE WHEN rn=2 THEN buyer END) buyer2,
       MAX(CASE WHEN rn=3 THEN buyer END) buyer3
FROM cte
GROUP BY supplier;

Un SQLfiddle para probar .