view db/migrate/20130201184705_add_unique_index_on_tokens_value.rb @ 1535:e2c122809c5c live

Update download count only after sending file (if send_file fails, does it throw and avoid this? unsure)
author Chris Cannam
date Wed, 11 Feb 2015 16:16:07 +0000
parents 261b3d9a4903
children
line wrap: on
line source
class AddUniqueIndexOnTokensValue < ActiveRecord::Migration
  def up
    say_with_time "Adding unique index on tokens, this may take some time..." do
      # Just in case
      duplicates = Token.connection.select_values("SELECT value FROM #{Token.table_name} GROUP BY value HAVING COUNT(id) > 1")
      Token.where(:value => duplicates).delete_all
  
      add_index :tokens, :value, :unique => true, :name => 'tokens_value'
    end
  end

  def down
    remove_index :tokens, :name => 'tokens_value'
  end
end