我在rails中有一个方法正在做这样的事情:
a = Foo.new("bar")
a.save
b = Foo.new("baz")
b.save
...
x = Foo.new("123", :parent_id => a.id)
x.save
...
z = Foo.new("zxy", :parent_id => b.id)
z.save
问题是我添加的实体越多,这需要的时间就越长。我怀疑这是因为它必须为每条记录访问数据库。由于它们是嵌套的,我知道在拯救父母之前我无法拯救孩子,但我想一次拯救所有父母,然后拯救所有孩子。做这样的事情会很好:
a = Foo.new("bar")
b = Foo.new("baz")
...
saveall(a,b,...)
x = Foo.new("123", :parent_id => a.id)
...
z = Foo.new("zxy", :parent_id => b.id)
saveall(x,...,z)
只需两次数据库命中即可完成所有操作。有没有一种简单的方法可以在rails中做到这一点,还是我一次只能做一个?