Lo que debe hacer es, en primer lugar, anular la rotación de los datos y luego pivotarlos. Pero, lamentablemente, MySQL no tiene estas funciones, por lo que deberá replicarlas usando UNION ALL
consulta para la función de no pivotar y agregada con un CASE
para el pivote.
El unpivot o UNION ALL
piece toma los datos de su col1, col2, etc. y los convierte en múltiples filas:
select id, month, col1 value, 'col1' descrip
from yourtable
union all
select id, month, col2 value, 'col2' descrip
from yourtable
union all
select id, month, col3 value, 'col3' descrip
from yourtable
union all
select id, month, col4 value, 'col4' descrip
from yourtable
Consulte SQL Fiddle con demostración .
Resultado:
| ID | MONTH | VALUE | DESCRIP |
----------------------------------
| 101 | Jan | A | col1 |
| 102 | feb | C | col1 |
| 101 | Jan | B | col2 |
| 102 | feb | A | col2 |
| 101 | Jan | (null) | col3 |
| 102 | feb | G | col3 |
| 101 | Jan | B | col4 |
| 102 | feb | E | col4 |
Luego envuelve esto en una subconsulta para aplicar el agregado y el CASE
para convertir esto al formato que desee:
select descrip,
max(case when month = 'jan' then value else 0 end) jan,
max(case when month = 'feb' then value else 0 end) feb
from
(
select id, month, col1 value, 'col1' descrip
from yourtable
union all
select id, month, col2 value, 'col2' descrip
from yourtable
union all
select id, month, col3 value, 'col3' descrip
from yourtable
union all
select id, month, col4 value, 'col4' descrip
from yourtable
) src
group by descrip
Consulte SQL Fiddle con demostración
El resultado es:
| DESCRIP | JAN | FEB |
-----------------------
| col1 | A | C |
| col2 | B | A |
| col3 | 0 | G |
| col4 | B | E |