PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

SQL Transpose Linhas como Colunas


Usar:
  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

Esta é uma consulta dinâmica padrão, porque você está "orientando" os dados de linhas para dados colunares.