首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails 3数据库移植

Rails 3数据库移植
EN

Stack Overflow用户
提问于 2011-05-26 21:04:46
回答 1查看 43关注 0票数 0

必须快速地将表(大约30k条记录)从一个数据库移动到另一个具有不同名称的数据库。

我使用RoR的黑客解决方案是这样的:

代码语言:javascript
复制
for old_line in SaleItemsOld.where(:sale_id => old_sale.id)
    line = LineItems.new
        line.sale_id = new_sale.id
        ...
    line.save
end

我认为这应该通过在单个字符串中构建所有这些新行作为SQL查询,然后一次性执行来加快速度。

有没有更好的Rails解决方案呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-26 22:45:22

通常,您可以通过迁移和一些精心构建的SQL来完成这类工作。一般来说,我们的想法是做一些类似以下的事情:

代码语言:javascript
复制
INSERT INTO line_items (sale_id) SELECT id FROM sale_items_old

可以根据需要将其他值添加到插入列表和select规范中。

在迁移中,您可以通过将任意SQL放在up方法中来运行它:

代码语言:javascript
复制
def self.up
  execute("...")
end
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6138940

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档