我正在尝试制作一个复杂的SQL查询(在Rails 3中),用于访问属于用户关注者的照片对象。
场景将是:
所以这基本上就像将所有关注者的照片收集到一个集合中,根据照片创建日期对集合进行排序,然后对结果进行分页,一次只返回10张照片。这可能意味着最近的10张照片来自多个粉丝。
我有两个问题:
User.rb
文件中的关系建模为:
has_many :following, :through => :relationships, :source => :followed
has_many :followers, :through => :reverse_relationships, :source => :follower
has_many :photos, :dependent => :destroy, :order => 'created_at DESC'
其中关注者/关注者只是另一个用户。
感谢您提供的任何指导!非常感谢!!! :)
答案 0 :(得分:1)
我怀疑会出现延迟问题,因为在您的情况下,will_paginate会对查询设置限制。但是,您需要确保数据库中存在索引。
我认为这样的事情应该有效:
has_many :follower_photos, :class_name => 'Photo', :through => :followers
这就是你要找的东西吗?