RubyonRails has_many:通过关联控制器



这是我的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 :treatmentsTreatment belongs_to :user时,这两个关联都希望在treatments表中找到一个user_id列。您可能想更改您的迁移以包括:

t.integer :user_id

然后删除表(如果它们还没有数据!)并重新运行迁移。或者,您可以创建一个新的迁移并简单地运行:

    add_column :treatments, :user_id, :integer

最新更新