Опитвате се да отмените завъртането информацията. MySQL няма функция unpivot, така че ще трябва да използвате UNION ALL
заявка за преобразуване на колоните в редове:
select id, 'a' col, a value
from yourtable
union all
select id, 'b' col, b value
from yourtable
union all
select id, 'c' col, c value
from yourtable
Вижте SQL Fiddle с демонстрация .
Това може да стане и с помощта на CROSS JOIN
:
select t.id,
c.col,
case c.col
when 'a' then a
when 'b' then b
when 'c' then c
end as data
from yourtable t
cross join
(
select 'a' as col
union all select 'b'
union all select 'c'
) c
Вижте SQL Fiddle с демонстрация