sql >> Databáze >  >> RDS >> PostgreSQL

Výsledkem „seskupit podle“ bude více sloupců

Pokud je známo, že počet odlišných hodnot ve sloupci irt_tlevel je pevně daný, můžete použít podmíněnou agregaci.

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. Řádek s nejnovější hodnotou podle zákazníka a měsíce

  2. Jak nastavit časové pásmo na postgresql jdbc připojení vytvořeném flyway?

  3. Jak mohu získat název tabulky ve spouštěcí funkci PostgreSQL?

  4. Popisovač databáze DBI s AutoCommit nastaveným na 0 nevrací správná data pomocí SELECT?