如何使用连接表在Rails中创建has_many和belongs_to一个关联?

时间:2015-01-13 15:55:06

标签: ruby-on-rails ruby-on-rails-4 activerecord associations

我有以下模型: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

1 个答案:

答案 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