Rails:获取对象数组的关系

时间:2011-11-10 02:42:49

标签: ruby-on-rails ruby-on-rails-3 activerecord

我不知道这是否有一个好的答案。假设我有:

users = User.where(:location => "Utopia") #=> Returns [user1,user2,user3,user4]

我想做类似的事情:

users.photos #=> Returns all photos this group of users has

简单地将所有照片都放回去,而不是迭代它们。我问,因为每次迭代都是一个DB调用。有没有什么好方法可以进行单个数据库调用?

1 个答案:

答案 0 :(得分:5)

最直接的方法是使用eager loader:

users = User.where(:location => 'Utopia').includes(:photos)

这将在一次传递中获取用户,然后在另一次传递中获取关系及其相关照片。如果你使用JOIN或子选择,你可以把它全部包装成一个电话,这是你的电话,但它看起来像这样:

photos = Photo.includes(:user).where('users.location' => 'Utopia')

第12节Active Record Query Interface documentation中提供了更多信息。