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

MySQL - Jak udělat Oracle RANK() OVER (ORDER BY skóre DESC)

Přidejte další proměnnou:

SET @prev_value = NULL;
SET @rank_count = 0;
SET @rank_increasing = 0;
SELECT score
     , @rank_increasing := @rank__increasing + 1 AS row_num
     , CASE
       WHEN @prev_value = score 
          THEN @rank_count
       WHEN @prev_value := score 
          THEN @rank_count := @rank_increasing
       END AS rank
  FROM ...


  1. Kontingenční tabulka pomocí MySQL

  2. Vlastní generátor primárního klíče MySQL

  3. Kontrolní body databáze na serveru SQL Server

  4. GROUP BY v klauzuli UPDATE FROM