Mercurial > hg > soundsoftware-site
view db/migrate/072_add_enumerations_position.rb @ 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 | 622f24f53b42 |
line wrap: on
line source
class AddEnumerationsPosition < ActiveRecord::Migration def self.up add_column(:enumerations, :position, :integer, :default => 1) unless Enumeration.column_names.include?('position') Enumeration.find(:all).group_by(&:opt).each do |opt, enums| enums.each_with_index do |enum, i| # do not call model callbacks Enumeration.update_all "position = #{i+1}", {:id => enum.id} end end end def self.down remove_column :enumerations, :position end end