sql >> Database teknologi >  >> RDS >> PostgreSQL

At få 'gruppe efter' til at resultere i flere kolonner

Du kan bruge betinget aggregering, hvis det er kendt, at antallet af distinkte værdier i kolonnen irt_level er faste.

select 
extract(year from a.created) as Year,
a.testscoreid, 
sum(case when b.irt_tlevel = 'Low' then 1 else 0 end) as Low,
sum(case when b.irt_tlevel = 'Medium' then 1 else 0 end) as Medium,
sum(case when b.irt_tlevel = 'High' then 1 else 0 end) as High,
count(*) as Questions
from asmt.testscores a 
join asmt.questions b on a.questionid = b.questionid
where a.answered = True
group by Year, a.testscoreid
order by Year desc, a.testscoreid


  1. Sådan implementeres php-mysql datapaginering ved hjælp af dataudbydere

  2. Hvordan indstilles ORACLE_HOME-variablen korrekt på Ubuntu 9.x?

  3. Migrering fra AnswerHub til WordPress:A Tale of 10 Technologies

  4. php mysql - skal jeg tilføje feltet kategorinavn til en tabel eller ej?