Mysql
 sql >> Baza danych >  >> RDS >> Mysql

zapytanie o ranking użytkownika w tabelach jeden-do-wielu

SELECT u.id,total_score,
 ( SELECT COUNT(*) FROM
    (SELECT u1.id, (IFNULL(u1.freebee,0)+ IFNULL(SUM(score),0)) as total_score
     FROM users u1
     LEFT JOIN games g ON (g.userId = u1.id)
     GROUP BY u1.id
    )x1
   WHERE x1.total_score > x.total_score
 )+1 as rank,

( SELECT COUNT(DISTINCT total_score) FROM
    (SELECT u1.id, (IFNULL(u1.freebee,0)+ IFNULL(SUM(score),0)) as total_score
     FROM users u1
     LEFT JOIN games g ON (g.userId_Id = u1.id)
     GROUP BY u1.id
    )x1
   WHERE x1.total_score > x.total_score
 )+1 as dns_rank

 FROM users u

 LEFT JOIN
  ( SELECT u1.id, (IFNULL(u1.freebee,0)+ IFNULL(SUM(score),0)) as total_score
    FROM users u1
    LEFT JOIN games g ON (g.userId = u1.id)
    GROUP BY u1.id
  )x ON (x.id = u.id)

rank - (ranga normalna - np. - 1,2,2,4,5), dns_rank - gęsta ranga (1,2,2,3,4). Kolumna total_score - tylko do debugowania...



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Średnia długość rzędu wyższa niż możliwa

  2. Zapisz tekst arabski w bazie danych MySQL

  3. MySQL Workbench:jak wyświetlać ostrzeżenia?

  4. Jak działa funkcja TRIM() w MySQL

  5. tymczasowo wyłącz zdalny dostęp do mysql