我正在尝试在我的ruby on rails应用程序中实现以下功能。这也是我的数据库布局和模型名称。
然而,这对我来说并不是很有效。
用户模型:
class User < ActiveRecord::Base
has_many :follows
has_many :users, :through => :follows
end
关注模特:
class Follow < ActiveRecord::Base
belongs_to :user, :foreign_key => :follow_user_id
end
我用它来调试:
<% current_user.follows.each do |x| %>
<%= debug x.user %>
<% end %>
我不知道如何以相反的方式做到这一点,我甚至不确定我是否正确行事。任何帮助表示赞赏。
答案 0 :(得分:1)
你有正确的想法,你还没有完成协会。首先,请注意User已连接两次Follow - 每个方向一次。
rails g model User email:string name:string
rails g model Follow user:references follow_user:references
然后:
class User < ActiveRecord::Base
has_many :follows, inverse_of: :user
has_many :followers, through: :follows
has_many :followings, class_name: 'Follow', foreign_key: :follow_user_id, inverse_of: :follower
has_many :users_i_follow, through: :followings, source: :user
end
class Follow < ActiveRecord::Base
belongs_to :user, inverse_of: :follows
belongs_to :follower, inverse_of: :followers, class_name: 'User', foreign_key: :follow_user_id
end
现在,对于一个用户,您可能会使用两个关联:“关注者”和“users_i_follow”。
mdchaney$ bundle exec rails c
Loading development environment (Rails 4.1.5)
2.1.1 :001 > u = User.create(:email => 'test@comor.net', :name => 'Leader Guy')
=> #<User id: 1, email: "test@comor.net", name: "Leader Guy", created_at: "2014-09-26 18:48:52", updated_at: "2014-09-26 18:48:52">
2.1.1 :002 > u2 = User.create(:email => 'follower@comor.net', :name => 'Follower Guy')
=> #<User id: 2, email: "follower@comor.net", name: "Follower Guy", created_at: "2014-09-26 18:49:13", updated_at: "2014-09-26 18:49:13">
2.1.1 :003 > u3 = User.create(:email => 'follower3@comor.net', :name => 'Follower Guy, III')
=> #<User id: 3, email: "follower3@comor.net", name: "Follower Guy, III", created_at: "2014-09-26 18:49:25", updated_at: "2014-09-26 18:49:25">
2.1.1 :004 > u.followers
=> #<ActiveRecord::Associations::CollectionProxy []>
2.1.1 :005 > Follow.create(:user => u, :follower => u2)
=> #<Follow id: 1, user_id: 1, follow_user_id: 2, created_at: "2014-09-26 18:50:12", updated_at: "2014-09-26 18:50:12">
2.1.1 :006 > Follow.create(:user => u, :follower => u3)
=> #<Follow id: 2, user_id: 1, follow_user_id: 3, created_at: "2014-09-26 18:50:14", updated_at: "2014-09-26 18:50:14">
2.1.1 :007 > u = User.find(1)
=> #<User id: 1, email: "test@comor.net", name: "Leader Guy", created_at: "2014-09-26 18:48:52", updated_at: "2014-09-26 18:48:52">
2.1.1 :008 > u.followers
=> #<ActiveRecord::Associations::CollectionProxy [#<User id: 2, email: "follower@comor.net", name: "Follower Guy", created_at: "2014-09-26 18:49:13", updated_at: "2014-09-26 18:49:13">, #<User id: 3, email: "follower3@comor.net", name: "Follower Guy, III", created_at: "2014-09-26 18:49:25", updated_at: "2014-09-26 18:49:25">]>
2.1.1 :009 > u.follows
=> #<ActiveRecord::Associations::CollectionProxy [#<Follow id: 1, user_id: 1, follow_user_id: 2, created_at: "2014-09-26 18:50:12", updated_at: "2014-09-26 18:50:12">, #<Follow id: 2, user_id: 1, follow_user_id: 3, created_at: "2014-09-26 18:50:14", updated_at: "2014-09-26 18:50:14">]>
2.1.1 :010 > u2 = User.find(2)
=> #<User id: 2, email: "follower@comor.net", name: "Follower Guy", created_at: "2014-09-26 18:49:13", updated_at: "2014-09-26 18:49:13">
2.1.1 :011 > u2.followers
=> #<ActiveRecord::Associations::CollectionProxy []>
2.1.1 :012 > u2.follows
=> #<ActiveRecord::Associations::CollectionProxy []>
2.1.1 :013 > u2.followings
=> #<ActiveRecord::Associations::CollectionProxy [#<Follow id: 1, user_id: 1, follow_user_id: 2, created_at: "2014-09-26 18:50:12", updated_at: "2014-09-26 18:50:12">]>
2.1.1 :014 > u2.users_i_follow
=> #<ActiveRecord::Associations::CollectionProxy [#<User id: 1, email: "test@comor.net", name: "Leader Guy", created_at: "2014-09-26 18:48:52", updated_at: "2014-09-26 18:48:52">]>
答案 1 :(得分:0)
这也可以通过单个has_many :through
关联来完成。参见the related answer。
这是针对friends / friendships
问题的,但基本上与followers / follows
问题相同。