crowdAI/crowdai

View on GitHub
doc/technical/archived_migrations/20160614140653_ongoing_leaderboard.rb

Summary

Maintainability
A
3 hrs
Test Coverage
class OngoingLeaderboard < 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.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,
                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
                       WHERE c.post_challenge = FALSE
                      GROUP BY c.challenge_id, c.participant_id) cnt
              WHERE ((p.id = s.participant_id)
                        AND ((s.grading_status_cd)::text = 'graded'::text)
                        AND (cnt.challenge_id = s.challenge_id)
                        AND (cnt.participant_id = s.participant_id))
    ) l
      WHERE (l.row_num = 1)
      ORDER BY l.score DESC, l.score_secondary
    "

    create_view :ongoing_leaderboards,
    "
    SELECT l.row_num,
        l.id,
        l.challenge_id,
        l.participant_id,
        l.name,
        l.entries,
        l.score,
        l.score_secondary,
        l.post_challenge,
        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,
                s.score,
                s.score_secondary,
                s.post_challenge,
                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.grading_status_cd)::text = 'graded'::text)
                        AND (cnt.challenge_id = s.challenge_id)
                        AND (cnt.participant_id = s.participant_id))
    ) l
      WHERE (l.row_num = 1)
      ORDER BY l.score DESC, l.score_secondary
    "
  end
end