必须快速地将表(大约30k条记录)从一个数据库移动到另一个具有不同名称的数据库。
我使用RoR的黑客解决方案是这样的:
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解决方案呢?
发布于 2011-05-26 22:45:22
通常,您可以通过迁移和一些精心构建的SQL来完成这类工作。一般来说,我们的想法是做一些类似以下的事情:
INSERT INTO line_items (sale_id) SELECT id FROM sale_items_old可以根据需要将其他值添加到插入列表和select规范中。
在迁移中,您可以通过将任意SQL放在up方法中来运行它:
def self.up
execute("...")
endhttps://stackoverflow.com/questions/6138940
复制相似问题