Я пытаюсь обойти неспособность Oracle изменить тип столбца с данными в нем.Я кеширую правильное значение атрибута, устанавливаю его равным nil, переименовываю столбец и затем пытаюсь переустановить атрибут:
class SwitchToForeignKeys < ActiveRecord::Migration
def self.up
registration_countries = {}
Registration.all.each do |r|
if c = Country.find_by_name(r.country)
registration_countries[r.id] = c.id
r.country = nil
r.save
end
end
rename_column :registrations, :country, :country_id
change_column :registrations, :country_id, :integer
Registration.reset_column_information
registration_countries.each do |reg_id, country_id|
r = Registration.find(reg_id)
r.reload
r.country_id = country_id
r.save
end
end
end
При запуске миграции я получаю эту ошибку на втором r.save:
undefined method `country' for #<Registration:0x7f409698be48>