annotate db/migrate/.svn/text-base/072_add_enumerations_position.rb.svn-base @ 436:4eb486dbf730 bug_169

If the remote repo URL changes, move aside the existing local mirror and start afresh. (Not yet tested: checkpointing this prior to working on a different aspect of the problem)
author Chris Cannam
date Mon, 06 Jun 2011 12:53:06 +0100
parents 513646585e45
children
rev   line source
Chris@0 1 class AddEnumerationsPosition < ActiveRecord::Migration
Chris@0 2 def self.up
Chris@0 3 add_column(:enumerations, :position, :integer, :default => 1) unless Enumeration.column_names.include?('position')
Chris@0 4 Enumeration.find(:all).group_by(&:opt).each do |opt, enums|
Chris@0 5 enums.each_with_index do |enum, i|
Chris@0 6 # do not call model callbacks
Chris@0 7 Enumeration.update_all "position = #{i+1}", {:id => enum.id}
Chris@0 8 end
Chris@0 9 end
Chris@0 10 end
Chris@0 11
Chris@0 12 def self.down
Chris@0 13 remove_column :enumerations, :position
Chris@0 14 end
Chris@0 15 end