ruby on rails has_many: через ассоциацию, которая имеет две колонки с одинаковой моделью - PullRequest
3 голосов
/ 01 июня 2011

У меня есть следующая модель:

class UserShareTag < ActiveRecord::Base
  attr_protected :sharee_id, :post_id, :sharer_id

  belongs_to :sharer, :class_name => "User"
  belongs_to :post
  belongs_to :sharee, :class_name => "User"

  validates :sharer_id, :presence => true
  validates :sharee_id, :presence => true
  validates :post_id, :presence => true
end

В модели Post у меня есть следующая строка:

has_many :user_share_tags, :dependent => :destroy
has_many :user_sharers, :through => :user_share_tags, :uniq => true, :class_name => "User"
has_many :user_sharees, :through => :user_share_tags, :uniq => true, :class_name => "User"

Как передать, что: user_sharers должен соответствовать: sharer_id?и: user_sharees должно соответствовать: sharee_id?Поскольку они обе являются одной и той же моделью пользователя, я не уверен, что делать.

Несколько связанная с этим проблема - в модели пользователя у меня есть:

has_many :user_share_tags, :dependent => :destroy
has_many :user_shared_posts, :through => :user_share_tags, :uniq => true, :class_name => "Post"
has_many :recommended_posts, :through => :user_share_tags, :uniq => true, :class_name => "Post"

Как включить дополнительную логику, которая: user_shared_posts должен содержать сообщения, где: sharer_id является user_id?и: рекомендованные_позиции должны содержать сообщения, в которых: sharee_id - это идентификатор_пользователя?

Заранее спасибо!

1 Ответ

3 голосов
/ 01 июня 2011

Вам просто нужно добавить параметр :source к вашим has_many ассоциациям (и вам не нужен параметр :class_name):

has_many :user_sharers, :through => :user_share_tags, :source => :sharer, :uniq => true, :class_name => "User"
has_many :user_sharers, :through => :user_share_tags, :source => :sharee, :uniq => true, :class_name => "User"

Затем в вашей модели User,вам нужна дополнительная has_many ассоциация:

has_many :user_share_tags_as_sharee, :class_name => "UserShareTag", :foreign_key => :sharee_id, :dependent => :destroy
has_many :user_share_tags_as_sharer, :class_name => "UserShareTag", :foreign_key => :sharer_id, :dependent => :destroy
has_many :user_shared_posts, :source => :post, :through => :user_share_tags_as_sharer, :uniq => true
has_many :recommended_posts, :source => :post, :through => :user_share_tags_as_sharee, :uniq => true
...