当前位置:  开发笔记 > 编程语言 > 正文

合并Rails数据库

如何解决《合并Rails数据库》经验,为你挑选了2个好方法。

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

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

您建议合并两个数据库中的数据?



1> 小智..:

使用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取决于记录的数量和模型之间的关联.



2> Daniel Beard..:

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

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

#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或其他的组进行.

推荐阅读
我我檬檬我我186
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有