Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Transponieren Sie Zeilen basierend auf der ID-Spalte in Spalten

Sie können dafür die Pivot-Klausel von SQL Server verwenden:

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

oder Sie können manuell schwenken:

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