加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-17 03:13:39 所属栏目:百科 来源:网络整理
导读:我不知道这是否有一个好的答案.比方说我有: users = User.where(:location = "Utopia") #= Returns [user1,user2,user3,user4] 我想做点什么: users.photos #= Returns all photos this group of users has 只需将所有照片都放回去,而不必迭代它们.我问,因
我不知道这是否有一个好的答案.比方说我有:

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中提供了更多信息.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读