PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Rails-Migrationen für PostgreSQL-Schemas

Ich habe eine schema_utils-Bibliothek, die ich verwende und die folgende Methode zur Handhabung von Migrationen hat:

  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

Ich verwende dann Migrationen wie gewohnt, damit ich weiterhin rake:migrateNow aufrufen kann, in Ihren Migrationen können Sie Folgendes verwenden:

...
schemas.each do |schema|
  SchemaUtils.with_schema(schema) do
    #Put migration code here
    #e.g. add_column :xyz, ...
  end
end

Da ich dazu neige, Schemata Kontocodes zuzuordnen, gehe ich wie folgt vor:

Account.for_each do |account|
  SchemaUtils.with_schema(account.code) do
    #Put migration code here
  end
end