我正在建立一个社交网站。我有一个用户表。每个用户可以有许多其他用户作为朋友,所以我有第二个桌面朋友:

user_id
friend_id

基于这个答案,我试图建立关系。我有,

class User < ActiveRecord::Base
  has_many :friends, :dependent => :destroy
  has_many :users, :through => :friends

  has_many :source_friend, :class_name => "Friend", :foreign_key => "friend_id", :dependent => :destroy
  has_many :source_users, :class_name => "User", :through => :friend_id
  ...

class Friend < ActiveRecord::Base
  belongs_to :user
  belongs_to :source_friend, :class_name => "User", :foreign_key => "friend_id"
end

当我尝试使用表格时,我的视图:

<% @user.users.each do |friend| %>
  <% if friend.status == User::ACTIVE %>
    <p>
      <%= link_to h(friend.name), :controller => "user", :id => h(friend.name)%>
    </p>
  <% end %>
<% end %>

返回的名称始终是源用户的名称,而不是目标朋友。

有帮助吗?

解决方案

好的,我已经解决了:将用户下的第二个条目更改为:

  has_many :users, :through => :friends, :source => :source_friend

我仍然不确定问题中的代码是否有一些不需要的碎屑?

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top