Anda dapat melakukan ini dengan PIVOT . Saat melakukan PIVOT, Anda dapat melakukannya dengan salah satu dari dua cara, dengan Pivot Statis yang akan Anda kodekan untuk mengubah baris atau Pivot Dinamis yang akan membuat daftar kolom saat run-time:
Pivot Statis (Lihat SQL Fiddle untuk Demo ):
select id, [user], [engineer], [manu], [OS]
from
(
select t.id
, t.[user]
, p.ticketid
, p.label
, p.value
from tickets t
inner join properties p
on t.id = p.ticketid
) x
pivot
(
min(value)
for label in ([engineer], [manu], [OS])
) p
Atau Anda dapat menggunakan Pivot Dinamis (Lihat SQL Fiddle for Demo ):
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX);
select @cols = STUFF((SELECT distinct ',' + QUOTENAME(p.label)
from tickets t
inner join properties p
on t.id = p.ticketid
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = 'SELECT id, [user], ' + @cols + ' from
(
select t.id
, t.[user]
, p.ticketid
, p.label
, p.value
from tickets t
inner join properties p
on t.id = p.ticketid
) x
pivot
(
min(value)
for label in (' + @cols + ')
) p '
execute(@query)
Kedua kueri akan mengembalikan hasil yang sama.