簡體   English   中英

我可以重建db / schema.rb以包含沒有遷移的多個數據庫嗎?

[英]Can I Rebuild db/schema.rb to Include Multiple Databases Without Migrations?

我有一個Rails 5應用程序,它使用三個不同的現有數據庫。 此應用程序不需要遷移。 我想構建db/schema.rb以包含所有三個數據庫,而不僅僅是主數據庫。 執行rake db:schema:dump使用主數據庫重建模式。 我相信有一種方法可以做到這一點,但由於某種原因,我一直在尋找的方式,我找不到任何關於這一點。 我發現的所有帖子都討論了如何使用來自不同數據庫的模型,而不是如何重建模式以包含所有數據庫。

大約一個月前我又開始看這個了。 在查看了幾個選項后,我找到了@ostinelli創建的解決方案,該解決方案非常好用且易於實現。 此解決方案為要維護的每個數據庫創建單獨的遷移,而不是將它們全部放在單個模式文件中。 我的目標主要是為每個數據庫建立一個模式,這對我來說是完成的。 有些部分我沒有實施,因為它們不需要。

http://www.ostinelli.net/setting-multiple-databases-rails-definitive-guide/

我為每個數據庫創建了單獨的數據庫yml文件,如下所示:

config/database_stats.yml

development:
  adapter: postgresql
  encoding: utf8
  host: localhost
  pool: 10
  database: myapp_stats_development
  username: postgres
  password:

test:
  adapter: postgresql
  encoding: utf8
  host: localhost
  pool: 10
  database: myapp_stats_test
  username: postgres
  password:

production:
  adapter: postgresql
  encoding: utf8
  url:  <%= ENV["DATABASE_STATS_URL"] %>
  pool: <%= ENV["DB_POOL"] || 5 %>

然后我為每個數據庫創建了單獨的數據庫rake任務:

lib/tasks/db_stats.rake

task spec: ["stats:db:test:prepare"]

namespace :stats do

  namespace :db do |ns|

    task :drop do
      Rake::Task["db:drop"].invoke
    end

    task :create do
      Rake::Task["db:create"].invoke
    end

    task :setup do
      Rake::Task["db:setup"].invoke
    end

    task :migrate do
      Rake::Task["db:migrate"].invoke
    end

    task :rollback do
      Rake::Task["db:rollback"].invoke
    end

    task :seed do
      Rake::Task["db:seed"].invoke
    end

    task :version do
      Rake::Task["db:version"].invoke
    end

    namespace :schema do
      task :load do
        Rake::Task["db:schema:load"].invoke
      end

      task :dump do
        Rake::Task["db:schema:dump"].invoke
      end
    end

    namespace :test do
      task :prepare do
        Rake::Task["db:test:prepare"].invoke
      end
    end

    # append and prepend proper tasks to all the tasks defined here above
    ns.tasks.each do |task|
      task.enhance ["stats:set_custom_config"] do
        Rake::Task["stats:revert_to_original_config"].invoke
      end
    end
  end

  task :set_custom_config do
    # save current vars
    @original_config = {
      env_schema: ENV['SCHEMA'],
      config: Rails.application.config.dup
    }

    # set config variables for custom database
    ENV['SCHEMA'] = "db_stats/schema.rb"
    Rails.application.config.paths['db'] = ["db_stats"]
    Rails.application.config.paths['db/migrate'] = ["db_stats/migrate"]
    Rails.application.config.paths['db/seeds'] = ["db_stats/seeds.rb"]
    Rails.application.config.paths['config/database'] = ["config/database_stats.yml"]
  end

  task :revert_to_original_config do
    # reset config variables to original values
    ENV['SCHEMA'] = @original_config[:env_schema]
    Rails.application.config = @original_config[:config]
  end
end

然后我為其他數據庫創建了自定義遷移生成器。

lib/generators/stats_migration_generator.rb

require 'rails/generators/active_record/migration/migration_generator'

class StatsMigrationGenerator < ActiveRecord::Generators::MigrationGenerator
  source_root File.join(File.dirname(ActiveRecord::Generators::MigrationGenerator.instance_method(:create_migration_file).source_location.first), "templates")

  def create_migration_file
    set_local_assigns!
    validate_file_name!
    migration_template @migration_template, "db_stats/migrate/#{file_name}.rb"
  end
end

我為每個數據庫創建了數據庫遷移,類似於:

rails g stats_migration create_clicks
create db_stats/migrate/20151201191642_create_clicks.rb
rake stats:db:create
rake stats:db:migrate

然后為其他數據庫創建單獨的數據庫初始化程序,然后修改每個模型

config/initializers/db_stats.rb

DB_STATS = YAML::load(ERB.new(File.read(Rails.root.join("config","database_stats.yml"))).result)[Rails.env]

class Click < ActiveRecord::Base
  establish_connection DB_STATS

end

我第一次寫這個問題時,我的應用程序中有三個數據庫。 我現在正在添加另一個數據庫。 我很感激@ostinelli寫的這個。 這讓我的生活更輕松。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM