【问题标题】:Merging Rails databases合并 Rails 数据库
【发布时间】:2010-09-15 05:12:12
【问题描述】:

我有两个结构相同的数据库。这些表有一个整数作为 Rails 中使用的主键。

如果我有一个患者表,我将让一个患者在一个数据库中使用主键 123,而另一个患者在另一个数据库中使用相同的主键。

对于合并两个数据库中的数据,您有什么建议?

【问题讨论】:

  • 您使用的是什么数据库引擎?另外(我没有太多 Rails 经验),Rails 是否为新记录分配 id 或数据库引擎是否这样做?
  • 在 Rails 中,ID 由数据库使用序列或自增整数字段类型分配。

标签: ruby-on-rails database-design merge


【解决方案1】:

如果您的数据库完全相同(数据不需要自定义处理)并且记录不多,您可以这样做(允许外键):

未经测试...但你明白了

#All models and their foreign keys
tales = {Patients => [:doctor_id, :hospital_id],
         Doctors => [:hospital_id],
         Hospitals}

ActiveRecord::Base.establish_connection :development

max_id = tables.map do |model|  
  model.maximum(:id)
end.max + 1000


tables.each do |model, fks|  
  ActiveRecord::Base.establish_connection :development
  records = model.find(:all)

  ActiveRecord::Base.establish_connection :production
  records.each do |record|
    #update the foreign keys
    fks.each do |attr|
      record[attr] += max_id if not record[attr].nil?
    end
    record.id += max_id

    model.create record.attributes
  end
end

如果您有很多记录,您可能不得不以某种方式将其分成几部分……以 10k 为一组进行。

【讨论】:

    【解决方案2】:

    顺便说一句,这可能是一个 rake 或 capistrano 任务而不是迁移更有意义。

    【讨论】:

      【解决方案3】:

      使用 config/database.yml 中的条目设置您的两个数据库,然后生成新的迁移。

      在迁移中使用 ActiveRecord::Base.establish_connection 在两个数据库之间进行切换,如下所示:

      def self.up
        ActiveRecord::Base.establish_connection :development
        patients = Patient.find(:all)
        ActiveRecord::Base.establish_connection :production
        patients.each { |patient| Patient.create patient.attributes.except("id") }
      end
      

      YMMV 取决于记录的数量和模型之间的关联。

      【讨论】:

      • 当我将数据库从开发切换到生产时,我遇到了问题,然后更新了患者变量的记录。例如,当我切换数据库时,我有 10 个开发用户和 3 个生产用户,患者变量从 10 个用户转换为 3 个。你能帮忙吗? :)
      猜你喜欢
      • 2019-03-14
      • 1970-01-01
      • 2012-03-13
      • 2014-11-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多