假设我们有三个模型 PATIENTS、NURSES 和它们的关联模型 APPOINTMENTS。
本周所有患者都必须与他们的护士见面。
一个病人有很多护士,一个护士有很多病人。同样,一个病人有很多预约,但每个护士只有一个,一个护士有很多预约,但每个病人只有一个。
class Patient < ActiveRecord::Base
has_many :appointments
has_many :nurses, :through => :appointments
end
class Nurse < ActiveRecord::Base
has_many :appointments
has_many :patients, :through => :appointments
end
class Appointment < ActiveRecord::Base
belongs_to :patient
belongs_to :nurse
end
显然,预约属于病人和护士。
但是,我还想要一种方法让护士能够勾选患者是否出现。我在迁移中实现了这一点,如下所示:
class CreateAppointments < ActiveRecord::Migration
def self.up
create_table :appointments do |t|
t.references :patient
t.references :nurse
t.boolean "present", :default => false
t.timestamps
end
add_index :job_enrollments, ['patient_id', 'nurse_id']
end
def self.down
drop_table :appointments
end
结尾
在控制台中,我可以创建所有内容的实例,并且可以执行以下操作:
appt = Appointment.new
patient = Patient.new
nurse = Nurse.new
patient.appointments << appt
nurse.appointments << appt
现在,问题来了:我如何实现它,以便该约会中的护士能够将布尔值编辑为 TRUE?到目前为止,我可以通过键入以下内容来更改约会实例的值:
appt.present = true
但这不是我想要的。我希望护士能够修改此关联,并阻止患者更改任何内容。
我不应该为此使用丰富的关联吗?