sql >> Database >  >> RDS >> PostgreSQL

sql - groepeer op in bereiken om bereiken zonder waarden op te nemen

Probeer deze zoekopdracht (ook op 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;

BEWERKEN:

U kunt het bereik eenvoudig aanpassen door parameters te wijzigen in generate_series() . Het is mogelijk om de volgende constructie te gebruiken om ervoor te zorgen dat ranges zal altijd uw scores dekken:

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

voor de ranges CTE.



  1. Hoe PHP in te checken als er meer PDO-parameters zijn opgegeven dan nodig?

  2. Oracle sql draaitabel-querytabel

  3. pgadmin4 query tool komt altijd terug niet verbonden

  4. STRING_SPLIT() in SQL Server 2016:vervolg #1