Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Trasponi le righe in colonne in base alla colonna ID

puoi utilizzare la clausola pivot di SQL Server per questo:

select
    p.*
from Table1
pivot(
    max([Field Selection])
    for [Field Name] in ([Rating 1], [Rating 2], [Rating 3])
) as p

oppure puoi ruotare manualmente:

select
    ID,
    max(case when [Field Name] = 'Rating 1' then [Field Selection] end) as [Rating 1], 
    max(case when [Field Name] = 'Rating 2' then [Field Selection] end) as [Rating 2],
    max(case when [Field Name] = 'Rating 3' then [Field Selection] end) as [Rating 3]
from Table1
group by ID

sql fiddle demo