sql >> Databasteknik >  >> RDS >> PostgreSQL

postgresql - få räkning efter värdeintervall

select name, 
       count(case when value <= 5 then 1 end) as "0-5",
       count(case when value > 5 and value <= 10 then 1 end) as "5-10",
       count(case when value > 10 and value <= 15 then 1 end) as "10-15"
from the_table
group by name;

Med den kommande versionen 9.4 kan detta skrivas lite mer läsvärt:

select name, 
       count(*) filter (where amount <= 5) as "0-5",
       count(*) filter (where value > 5 and value <= 10) as "5-10",
       count(*) filter (where value > 10 and value <= 15) as "10-15"
from the_table
group by name;



  1. Postgresql skillnad mellan två kolumner datum?

  2. Varför kastar Hibernate org.hibernate.exception.LockAcquisitionException?

  3. KONTROLLERA begränsningar i SQL Server

  4. Skapa och få åtkomst till OLTP-databaser och tabeller i minnet