Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Memilih catatan N terbesar dalam grup X

SELECT catX.category
       catX.interest
       t1.user_id
       t1.score
FROM 
    ( SELECT category 
           , interest 
      FROM tableX 
      WHERE user_id = @user_id_we_are_interested_in     --- specific user 
      ORDER BY interest DESC
      LIMIT @X                         --- top @X categories per specific user 
    ) AS catX 
  JOIN 
    tableX AS t1 
      ON t1.category = catX.category 
  LEFT JOIN 
    tableX AS t2 
      ON  t2.category = t1.category 
      AND t2.score > t1.score 
  GROUP BY t1.category
         , t1.user_id
  HAVING COUNT(t2.score) < @N                      --- top @N users per category 
  ORDER BY catX.interest DESC 
         , t1.score DESC 


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Pokoknya untuk Membatasi waktu Eksekusi Query MySQL?

  2. MySQLi gagal menyiapkan pernyataan

  3. Apa gunanya prosedur tersimpan?

  4. Laravel 4 tidak dapat menjalankan seluruh kueri RAW

  5. Batas SQL PILIH tetapi tidak GABUNG