Ik heb een schema_utils-bibliotheek die ik gebruik en die de volgende methode heeft voor het afhandelen van migraties:
def self.with_schema(schema_name, &block)
conn = ActiveRecord::Base.connection
old_schema_search_path = conn.schema_search_path
conn.schema_search_path = schema_name
begin
yield
ensure
conn.schema_search_path = old_schema_search_path
end
end
Ik gebruik vervolgens migraties zoals normaal, zodat ik rake:migrateNow kan blijven aanroepen, in uw migraties kunt u het volgende gebruiken:
...
schemas.each do |schema|
SchemaUtils.with_schema(schema) do
#Put migration code here
#e.g. add_column :xyz, ...
end
end
Omdat ik de neiging heb schema's toe te wijzen aan accountcodes, doe ik het volgende:
Account.for_each do |account|
SchemaUtils.with_schema(account.code) do
#Put migration code here
end
end