Получить все микросообщения, опубликованные людьми, за которыми следует текущий пользователь - PullRequest
0 голосов
/ 24 декабря 2011

Я создаю твиттер-клон и для построения временной шкалы мне нужно, чтобы все микросообщения были опубликованы кем-либо, за кем следует текущий пользователь.

Railstutorial.org реализует это следующим образом :

class Micropost < ActiveRecord::Base
  default_scope :order => 'microposts.created_at DESC'

  # Return microposts from the users being followed by the given user.
  scope :from_users_followed_by, lambda { |user| followed_by(user) }

  private

    # Return an SQL condition for users followed by the given user.
    # We include the user's own id as well.
    def self.followed_by(user)
      following_ids = %(SELECT followed_id FROM relationships
                        WHERE follower_id = :user_id)
      where("user_id IN (#{following_ids}) OR user_id = :user_id",
            { :user_id => user })
    end
end

Но я чувствую, что суб-выбор немного грязный, и я думаю, что предпочел бы сделать это с помощью объединений.Вот SQL-запрос, который мне нужен:

SELECT m.*
FROM   Users u
       INNER JOIN Follows f
         ON u.id = f.follower_id
       INNER JOIN Microposts m
         ON s.user_id = f.followee_id
WHERE  u.id = [current users id]
ORDER  BY m.posted_at DESC 

Как я могу перевести это в ассоциации ActiveRecord?

Кроме того, какой метод обычно будет быстрее для этой задачи - дополнительный выбор или объединение?

1 Ответ

0 голосов
/ 24 декабря 2011

Попробуйте это:

class User
  has_many :posts

  has_many :follower_links, :class_name => "Follow", :foreign_key => :followee_id
  has_many :followers, :through => :follower_links, :source => follower

  has_many :followee_links, :class_name => "Follow", :foreign_key => :follower_id
  has_many :followees, :through => :followee_links, :source => followee

  def followee_posts
    Post.joins("JOIN (#{followees.to_sql}) AS followees 
      ON posts.user_id = followees.id")
  end
end

class Follow
  belongs_to :followee, :class_name => "User"
  belongs_to :follower, :class_name => "User"
end

class Post
  belongs_to :user
end
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...