crowdAI/crowdai

View on GitHub
doc/technical/archived_migrations/20160405125530_remove_username.rb

Summary

Maintainability
A
1 hr
Test Coverage
class Removename < ActiveRecord::Migration
  def change
    drop_view :leaderboards;
    create_view :leaderboards, "
    SELECT s.id,
           s.competition_id,
           s.user_id,
           u.name,
           NULL :: integer AS team_id,
           s.score,
           cnt.entries,
           s.created_at,
           s.updated_at
    FROM   submissions s,
           users u,
           (SELECT submissions.competition_id,
                   submissions.user_id,
                   submissions.team_id,
                   Count(*) AS entries
            FROM   submissions
            GROUP  BY submissions.competition_id,
                      submissions.user_id,
                      submissions.team_id) cnt
    WHERE  ( ( u.id = s.user_id )
             AND ( s.evaluated = TRUE )
             AND ( s.user_id = cnt.user_id )
             AND ( s.competition_id = cnt.competition_id )
             AND ( s.score = (SELECT Max(m.score) AS MAX
                              FROM   submissions m
                              WHERE  ( ( m.competition_id = s.competition_id )
                                       AND ( m.user_id = s.user_id )
                                       AND ( m.evaluated = TRUE ) )) ) )
                                       "
  end
end