我有以下模型:List
具有(name和user_id字段)和User
。
每个列表都有很多用户。每个列表属于一个用户。
我创建了client_lists
表:
class CreateClientListsTable < ActiveRecord::Migration
def change
create_table :client_lists do |t|
t.integer :user_id
t.integer :list_id
end
add_index :client_lists, :user_id
add_index :client_lists, :list_id
end
end
现在,对于第一个关系,很容易说一个列表属于一个用户而且一个用户有很多列表:
class List < ActiveRecord::Base
belongs_to :user
validates :user, :presence => true
end
并且
class User < ActiveRecord::Base
has_many :lists, :dependent => :destroy
end
无论如何,我应该如何通过client_lists表找到客户列表?
我为List
添加了HABTM关系class List < ActiveRecord::Base
has_and_belongs_to_many :clients, :join_table => "client_lists", :foreign_key => "user_id"
end
然后尝试List.first.clients
并收到以下错误:
NameError: uninitialized constant List::Client
答案 0 :(得分:1)
我必须创建ClientLists
模型:
class ClientLists < ActiveRecord::Base
belongs_to :user
belongs_to :list
end
然后将以下内容添加到List模型中:
has_many :client_lists, :class_name => "ClientLists", :foreign_key => "list_id"
has_many :clients, through: :client_lists, source: :user