class CreatePropositionsForExistingEvents < ActiveRecord::Migration def up events = execute 'SELECT * FROM events' events.each do |event| execute "INSERT INTO propositions (proposer_id, proposition_accepting_id, proposition_accepting_type, proposable_id, proposable_type, status, created_at, updated_at) VALUES (#{event['user_id']}, #{event['track_id']}, 'Track', #{event['id']}, 'Event', #{event['state']}, '#{event['created_at']}', '#{event['updated_at']}')" end end def down event_ids = execute('SELECT * FROM events').map { |event| event['id'] } execute "DELETE FROM propositions WHERE proposable_id IN (#{event_ids.join(', ')}) AND proposable_type = 'Event'" end end