sql >> Databasteknik >  >> RDS >> PostgreSQL

sql - gruppera efter i intervall för att inkludera intervall utan värden

Testa den här frågan (även på SQL Fiddle ):

WITH ranges AS (
    SELECT (ten*10)::text||'-'||(ten*10+9)::text AS range,
           ten*10 AS r_min, ten*10+9 AS r_max
      FROM generate_series(0,9) AS t(ten))
SELECT r.range, count(s.*)
  FROM ranges r
  LEFT JOIN scores s ON s.score BETWEEN r.r_min AND r.r_max
 GROUP BY r.range
 ORDER BY r.range;

EDIT:

Du kan enkelt justera intervallet genom att ändra parametrar till generate_series() . Det är möjligt att använda följande konstruktion för att säkerställa att ranges kommer alltid att täcka dina poäng:

SELECT (ten*10)::text||'-'||(ten*10+9)::text AS range,
       ten*10 AS r_min, ten*10+9 AS r_max
  FROM generate_series(0,(SELECT max(score)/10 FROM scores)) AS t(ten))

för ranges CTE.



  1. Fråga i Oracle för löpande summa

  2. Hur fungerar FULLTEXT INDEX på flera kolumner?

  3. Ändra användarlösenord via jdbc. Problem med pass som innehåller frågetecken

  4. Avfyra och glöm DB-loggning med ASP.NET