これは、古いデータベースからデータを移動するためのコードです。
class Old < ActiveRecord::Base
establish_connection :old_version
self.abstract_class = true
class Recipe < self
set_table_name :recipes
has_many :uploaded_files, :as => :storage
end
class UploadedFile < self
set_table_name :uploaded_files
belongs_to :storage, :polymorphic => true
end
end
次のコードを実行すると
Old::Recipe.all.each do |recipe|
puts recipe.uploaded_files.to_sql
end
このSQLを実行します
SELECT `uploaded_files`.* FROM `uploaded_files` WHERE `uploaded_files`.`storage_id` = 38 AND `uploaded_files`.`storage_type` = 'Old::Recipe'
問題は私が得ることです:
`storage_type` = 'Old::Recipe'
しかし、私は必要です:
`storage_type` = 'Recipe'
ポリモーフィック関係のクラスを変更するにはどうすればよいですか?
のドキュメントはhas_many
私に答えを与えません。