Active Record如何将记录添加到has_many:通过rails中的关联

时间:2014-12-11 11:56:48

标签: ruby-on-rails ruby activerecord has-many-through

我的has_many问题非常严重:通过关联。 模型看起来像这样:

class User < ActiveRecord::Base
  has_many :roles
  has_many :datasets, through: :roles
  has_secure_password
end

class Role < ActiveRecord::Base
  belongs_to :user
  belongs_to :dataset
end

class Dataset < ActiveRecord::Base
  has_many :roles
  has_many :users, through: :roles
end

我想在每次创建新数据集时向角色添加记录。这应该 使用新的数据集创建,现有的用户'管理员'和角色的列名称应设置为'管理员'。

我尝试了在Stackoverflow上找到的所有东西,但没有任何东西适合我。

DatasetController 中的创建方法如下所示:

def create
    @dataset = Dataset.new(dataset_params)
    @dataset.save
    @user = User.find_by(name: 'Admin')
    @dataset.users << @user
    #@dataset.roles.create(user: @user, dataset: @dataset, name: 'Admin')    
    respond_with(@dataset)
  end

我尝试了<<运算符和create方法。

第一个结果是:

ActiveRecord::UnknownAttributeError in DatasetsController#create
unknown attribute: dataset_id

第二个:

ActiveModel::MissingAttributeError in DatasetsController#create
can't write unknown attribute `user_id

有谁知道我为什么会收到这些错误?

my schema.rb:

create_table "datasets", force: true do |t|
  t.string   "name"
  t.text     "description"
  t.datetime "created_at"
  t.datetime "updated_at"
end

create_table "roles", force: true do |t|
  t.string   "name"
  t.datetime "created_at"
  t.datetime "updated_at"
end

create_table "users", force: true do |t|
  t.string   "name"
  t.string   "mail"
  t.string   "password_digest"
  t.datetime "created_at"
  t.datetime "updated_at"
end

1 个答案:

答案 0 :(得分:0)

您的Role模型需要列来引用它所属的UserDataset。没有这些,就不知道谁属于谁。

因此,您只需创建一个迁移来添加这些列:

class AddRefererColumnsToRole < ActiveRecord::Migration
  def change
    add_column :roles, :user_id, :integer
    add_column :roles, :dataset_id, :integer
  end
end