Ruby on Rails has_many:通过Association控制器

时间:2016-04-03 12:06:39

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

这些是我的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

它不会保存并只渲染“新”。

我有两个问题:

1-如何编写我的创建控制器?

2-如何根据患者检索我的治疗方法。我应该在患者的“show”方法中定义哪些变量来检索其治疗方案?

1 个答案:

答案 0 :(得分:1)

当您说User has_many :treatmentsTreatment belongs_to :user时,两个关联都希望在user_id中找到treatments列表。您可能希望将迁移更改为包括:

t.integer :user_id

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

    add_column :treatments, :user_id, :integer