crowdAI/crowdai

View on GitHub
doc/technical/archived_migrations/20160423121002_fix_leaderboards3.rb

Summary

Maintainability
A
1 hr
Test Coverage
class FixLeaderboards3 < ActiveRecord::Migration
  def change
    drop_view :leaderboards
    create_view :leaderboards,
    "
     SELECT l.row_num,
        l.id,
        l.challenge_id,
        l.participant_id,
        l.name,
        l.entries,
        l.team_id,
        l.score,
        l.score_secondary,
        l.created_at,
        l.updated_at
       FROM ( SELECT row_number() OVER (PARTITION BY s.challenge_id, s.participant_id ORDER BY s.score DESC, s.score_secondary) AS row_num,
                s.id,
                s.challenge_id,
                s.participant_id,
                p.name,
                cnt.entries,
                NULL::INTEGER AS team_id,
                s.score,
                s.score_secondary,
                s.created_at,
                s.updated_at
               FROM submissions s,
                participants p,
                ( SELECT c.challenge_id,
                        c.participant_id,
                        count(c.*) AS entries
                       FROM submissions c
                      GROUP BY c.challenge_id, c.participant_id) cnt
              WHERE p.id = s.participant_id
                AND s.evaluated = TRUE
                AND cnt.challenge_id = s.challenge_id
                AND cnt.participant_id = s.participant_id
                AND s.score IS NOT null) l
      WHERE l.row_num = 1
      ORDER BY l.score DESC, l.score_secondary
    "
  end
end