sql >> Databáze >  >> RDS >> Mysql

Jak mohu vybrat pevný počet řádků pro každou skupinu?

Použijte:

SELECT x.a,
       x.b,
       x.distance
  FROM (SELECT t.a,
               t.b,
               t.distance
               CASE 
                 WHEN @distance != t.distance THEN @rownum := 1 
                 ELSE @rownum := @rownum + 1 
               END AS rank,
               @distance := t.distance
          FROM TABLE t
          JOIN (SELECT @rownum := 0, @distance := '') r
      ORDER BY t.distance --important for resetting the rownum variable) x
 WHERE x.rank <= 2
ORDER BY x.distance, x.a


  1. Rozdíl mezi CTE a SubQuery?

  2. MariaDB Server 10.0.33 je nyní k dispozici

  3. Úvod do ML{.NET}

  4. Běžný uživatel s oprávněním SYSBACKUP