我的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
答案 0 :(得分:0)
您的Role
模型需要列来引用它所属的User
和Dataset
。没有这些,就不知道谁属于谁。
因此,您只需创建一个迁移来添加这些列:
class AddRefererColumnsToRole < ActiveRecord::Migration
def change
add_column :roles, :user_id, :integer
add_column :roles, :dataset_id, :integer
end
end