2016-04-03 64 views
0

这些都是我的3种型号:Ruby on Rails的的has_many:通过关联控制器

模型用户:

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 

我是新来的铁轨,基本的想法是我希望我的用户有治疗属于一个特定的帕蒂ENT。

感谢我通过添加参考列来回答这个问题。现在我收不到,但它不保存任何治疗。我的意思是零件:

if @treat.save 
    flash[:success] = "new treatment added" 
    redirect_to root_url 
else 
    render 'new' 
end 

它不保存,只是渲染'新'。

我有2个问题:

1 - 我如何代码我创建控制器?

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

+1

你应该在'处理器'表中有'user_id'。 – Pavan

+0

如何添加? – Shahryar

+1

使用迁移将user_id添加为@Pavan之前在评论中写的,您可以使用像add_reference:treatments,:user,index:true这样的引用。 – unused

回答

1

当你说Userhas_many :treatmentsTreatmentbelongs_to :user,两个协会正期待找到你treatments表中的列user_id。你可能想改变你的迁移,包括:

t.integer :user_id 

然后放下你的表(如果他们有没有数据!)并重新运行迁移。或者,你可以创建一个新的迁移,并简单地运行:

add_column :treatments, :user_id, :integer 
+0

你可能想要添加一个索引,我也建议使用'add_reference'。 – unused

+0

我认为用户是病人 - 也许has_many:患者,foreign_key:“user_id”。 – Ronna

+0

不是用户不是病人 – Shahryar

相关问题