Mysql
 sql >> база данни >  >> RDS >> Mysql

Изчисляване на ранг в PHP/MySQL

Ако искате общо класиране, за съжаление трябва да сортирате цялата таблица. Просто казано, не можете да знаете ранга на някого в таблицата, без да знаете другите ранги в таблицата.

Въпреки това, ако се притеснявате за производителността, тук има доста лесно решение - кеширайте резултата от вашата заявка за класиране (може би в друга таблица на MySQL!) и го заявете за всички ваши четения. Когато някой публикува нов резултат, преизчислете временната си таблица. Можете периодично да изтривате всички записи под определен ранг (да речем, всеки, който се класира под 100, се премахва от таблицата с резултати), за да поддържате преизчисленията бързо, тъй като никой никога няма да се изкачи в ранг, след като бъде съборен от по-висок резултат.

# Create your overall leaderboards once
create table leaderboards (rank integer primary key, score_id integer, game varchar(65), user_id integer, index game_user_id_idx (game, user_id))


# To refresh your leaderboard, we'll query the ranks for the game into a temporary table, flush old records from scores, then copy
# the new ranked table into your leaderboards table.
# We'll use MySQL's CREATE TABLE...SELECT syntax to select our resultset into it directly upon creation.
create temporary table tmp_leaderboard (rank integer primary key auto_increment, score_id integer, game varchar(65), user_id integer)
  select ID, GameName, UserID, from scores where GameName = '$game' order by score desc;

# Remove old rankings from the overall leaderboards, then copy the results of the temp table into it.
delete from leaderboards where game = '$game';
insert into leaderboards (rank, score_id, game, user_id)
  select rank, score_id, game, user_id from tmp_leaderboard;

# And then clean up the lower scores from the Scores table
delete from scores join tmp_leaderboard on scores.id = tmp_leaderboard.score_id, scores.GameName = tmp_leaderboard.game where tmp_leaderboard.rank < 100;

# And we're done with our temp table
drop table tmp_leaderboard;

След това, когато искате да прочетете ранг за игра:

select rank from leaderboards where game = '$game' and user_id = '$user_id';


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Как трябва да направя индексиране за заявка с две условия за диапазон?

  2. Вмъкнете съдържанието на файла в колоната на MySQL таблицата

  3. Използване на Python и MySQL в ETL процеса:SQLAlchemy

  4. Как да свържете PHP към MySQL

  5. Как да конвертирате UTC в местно време в MySQL