这是我的3种型号:
用户型号:
class User < ActiveRecord::Base
has_many :patients, through: :treatments
has_many :treatments
.
.
.
患者模型:
class Patient < ActiveRecord::Base
has_many :user, through: :treatments
has_many :treatments, dependent: :destroy
.
.
.
治疗模型:
class Treatment < ActiveRecord::Base
belongs_to :patient
belongs_to :user
validates :patient_id, presence: true
default_scope -> { order(created_at: :desc) }
end
这是我的治疗表:
class CreateTreatments < ActiveRecord::Migration
def change
create_table :treatments do |t|
t.date :teartment_date
t.text :remark
t.float :fee
t.references :patient, index: true, foreign_key: true
t.timestamps null: false
end
add_index :treatments, [:patient_id, :created_at]
end
end
现在我想定义一个控制器来创建一个属于特定用户的患者的新治疗。
这是我的控制器:
def new
@treat = Treatment.new
end
def create
@userpatient = current_user.treatments.build(treat_params)
if @userpatient.save
flash[:success] = "new treatment added"
redirect_to root_url
else
render 'new'
end
end
但这是我收到的错误,而我想创建一个新的处理:
ActiveRecord::UnknownAttributeError in TreatmentsController#create
unknown attribute 'user_id' for Treatment.
这是current_user:
def current_user
if (user_id = session[:user_id])
@current_user ||= User.find_by(id: user_id)
elsif (user_id = cookies.signed[:user_id])
user = User.find_by(id: user_id)
if user && user.authenticated?(cookies[:remember_token])
log_in user
@current_user = user
end
end
end
我是rails的新手,基本想法是我希望我的用户得到属于特定患者的治疗。
感谢您的回复,我添加了一个参考栏,从而解决了这个问题。现在我没有,但这并不能挽救任何治疗。我指的是
if @treat.save
flash[:success] = "new treatment added"
redirect_to root_url
else
render 'new'
end
它不保存,只是呈现"new"。
我有两个问题:
1-如何对创建控制器进行编码?
2-如何根据患者检索我的治疗。我应该在患者"显示"方法中定义什么变量来检索其治疗?
当您说User
has_many :treatments
和Treatment
belongs_to :user
时,这两个关联都希望在treatments
表中找到一个user_id
列。您可能想更改您的迁移以包括:
t.integer :user_id
然后删除表(如果它们还没有数据!)并重新运行迁移。或者,您可以创建一个新的迁移并简单地运行:
add_column :treatments, :user_id, :integer