sql >> Database >  >> RDS >> PostgreSQL

Door `groeperen op` in meerdere kolommen te laten resulteren

U kunt voorwaardelijke aggregatie gebruiken als bekend is dat het aantal afzonderlijke waarden in de kolom irt_tlevel vast is.

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. Oracle PIVOT, twee keer?

  2. Hoe doe je een update + join in PostgreSQL?

  3. Mysql Group Met intervallen van 24 uur

  4. Query-uitvoer met inspringing