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

Konvertieren Sie Zeilen in Spalten in SQL

Sie können den Code PIVOT Tabellenoperator, um die Zeilen der Noten dieser Kurse in Spalten umzuwandeln, etwa so:

SELECT  
  Course, 
  [1] AS "Grade 1", 
  [2] AS "Grade 2", 
  [3] AS "Grade 3", 
  [4] AS "Grade 4"
FROM
(
  SELECT 
    Course, 
    Grade, 
    ROW_NUMBER() OVER(PARTITION BY Course 
                      ORDER BY COURSE) rownum 
  FROM Grades
) t
PIVOT 
(
   MAX(Grade)
   FOR rownum IN([1], [2], [3], [4])
) p;

SQL-Fiddle-Demo

Das ergibt:

COURSE    GRADE 1   GRADE 2      GRADE 3     GRADE 4
  A         15        17          (null)     (null)
  B         12      (null)        (null)     (null)
  C         10        18            0           9

Beachten Sie Folgendes: Ich habe die Ranking-Funktion ROW_NUMBER() mit PARTITION BY Course sie in vier Klassen zu unterteilen. Damit Sie sie dann in diese vier Gruppen einteilen können.

Wenn Sie dies dynamisch benötigen, falls die Anzahl der Noten unbekannt war. Sie können in diesem Fall dynamisches SQL verwenden, um die Notenliste wie folgt dynamisch zu generieren:

DECLARE @cols AS NVARCHAR(MAX);
DECLARE @query AS NVARCHAR(MAX);

SELECT @cols = STUFF((SELECT distinct ',' 
                        + QUOTENAME('Grade ' 
                        + CAST(ROW_NUMBER() OVER(PARTITION BY Course 
                                               ORDER BY Course) AS VARCHAR(10)))
                FROM Grades
                         FOR XML PATH(''), TYPE
                      ).value('.', 'NVARCHAR(MAX)'), 1, 1, '');

SELECT @query = 'SELECT Course, ' + @cols +  
                'FROM
                 (
                   SELECT 
                     Course, 
                     Grade, 
                     ''Grade '' + CAST(ROW_NUMBER() 
                                       OVER(PARTITION BY Course 
                                ORDER BY COURSE) AS VARCHAR(10)) rownum 
                   FROM Grades
                 ) t
                 PIVOT 
                 (
                   MAX(Grade)
                   FOR rownum IN(' + @cols + ')' +
                ') p';
execute(@query);

Dynamische SQL-Fiddle-Demo