如何通过连接表填充has_many中的字段

时间:2011-08-23 17:10:03

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

我有一个关于活动记录关联的问题,请参阅rails文档的这一部分:

http://guides.rubyonrails.org/association_basics.html#the-has_many-through-association

如果我们有三个模型:

class Physician < ActiveRecord::Base
  has_many :appointments
  has_many :patients, :through => :appointments
end

class Appointment < ActiveRecord::Base
  belongs_to :physician
  belongs_to :patient
end

class Patient < ActiveRecord::Base
  has_many :appointments
  has_many :physicians, :through => :appointments
end

文档说可以通过api以这种方式管理连接模型的集合:

physician.patients = patients

但是,如果约会模型(如链接示例中)有一个名为appointment_date的字段,并且我想在特定日期为医生和患者创建新约会,该怎么办? 以下代码将在约会表中创建一条记录,但是如何在第三步中填充appointment_date呢?

physician = Physician.first
patient = Patients.first
physician.patients << patient

这样的事情存在吗?

physician.patients.create( :patient => patient, 'appointment.appointment_time' => appointment_time ) 

2 个答案:

答案 0 :(得分:4)

旧问题,但应该回答 - 尽管您可以使用physician.patients方法直接分配给<<,但它会创建一个没有值的约会,这可能会也可能不会取决于商业规则。因此,创建关联的更常用方法是在其中一个上建立约会

demento = Physician.find_by_name('Dr. Demento'}
patient = Patient.new { :name => 'Mrs. Holloway' }
patient.appointments << Appointment.new { :physician => demento, :appointment_time => appt_time }

如果您愿意,可以将第2行和第3行合并。

您引用的文档中的行

physician.patients = patients

我认为狭隘的用例可能是,如果Demento有7名患者但由于不幸的死亡射线实验事件而失去Holloway夫人,那么你可以用6名现存患者的最新名单和他们的约会将被保留,Holloway夫人过去的约会将被自动删除(以便删除此处的任何记录,出于责任保险的原因?只有Demento会如此卑鄙)。

答案 1 :(得分:2)

您希望考虑嵌套路由,例如

resources :physicians do
  resource :patients
end

您可以使用form_for(@physician, @patient)

之类的内容

和网址类似physician/1/patient/23

在医生的背景下更新患者。