У меня есть модель пользователя (: имя,: пароль,: электронная почта), модель события (: имя,: и т. Д.) И модель интереса (: имя) [> все в единственном числе <] </p>
Затем я создал две таблицы соединения -> UsersInterests и EventsInterests; каждый из которых не содержит первичного ключа и состоит только из user_id / Interest_ID и Event_ID / Interest_id соответственно. [> Множественный <] </p>
В моих моделях используется плагин Nested Many Many *
user.rb => has_many :users_interests
has_many :interests, :through => :users_interests
has_many :events_interests, :through => :interests
has_many :events, :through => :events_interests
event.rb => has_many :events_interests
has_many :interests, :through => :events_interests
has_many :users_interests, :through => :interests
has_many :users, :through => :users_interests
interest.rb => has_and_belongs_to_many :users
has_and_belongs_to_many :events
events_interests.rb => belongs_to :interests
belongs_to :events
users_interests.rb => belongs_to :users
belongs_to :interests
Вот так ... Итак, я хотел создать named_scope для поиска всех событий, которые представляют интерес для определенного пользователя. Вот код, с которым мне кто-то помог.
named_scope :shares_interest_with_users, lambda {|user|
{ :joins => :users_interests,
:conditions => {:users_interests => {:user_id => user}}
}}
Когда я бегу от контроллера =>
@user = User.find(1)
@events = Event.shares_interest_with_user(@user)
Я получаю сообщение об ошибке:
uninitialized constant Event::EventsInterest
Кто-нибудь может увидеть, что я испортил?