ruby-on-rails – Rails:获取对象数组的关系

我不知道这是否有一个好的答案.比方说我有

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

我想做点什么:

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

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

解决方法

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

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

这将在一次通过中获取用户,然后在另一次通过中获取关系及其相关照片.如果你使用JOIN或subselect,你可以将它全部包装成一个调用,这是你的调用,但它看起来像这样:

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

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

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...