PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

SQL Zeilen als Spalten transponieren

Verwendung:

  SELECT r.user_id,
         MAX(CASE WHEN r.question_id = 1 THEN r.body ELSE NULL END) AS "Do you like apples?",
         MAX(CASE WHEN r.question_id = 2 THEN r.body ELSE NULL END) AS "Do you like oranges?",
         MAX(CASE WHEN r.question_id = 3 THEN r.body ELSE NULL END) AS "Do you like carrots?"
    FROM RESPONSES r
    JOIN QUESTIONS q ON q.id = r.question_id
GROUP BY r.user_id

Dies ist eine Standard-Pivot-Abfrage, da Sie die Daten von Zeilen zu Spaltendaten "schwenken".