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

sql - seskupit podle v rozsazích pro zahrnutí rozsahů bez hodnot

Zkuste tento dotaz (také na 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;

UPRAVIT:

Rozsah můžete snadno upravit změnou parametrů na generate_series() . Pro zajištění ranges je možné použít následující konstrukci vždy pokryje vaše skóre:

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))

pro ranges CTE.



  1. Formát data SQL

  2. Chybí mysql.sock; yielding OperationalError:(2002, nelze se připojit k místnímu serveru MySQL přes soket '/tmp/mysql.sock' (2))

  3. Dotaz MySQL DATETIME DIFF

  4. Chyby WAMP/MySQL nejsou ve správném jazyce