假设我们有三个模型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
显然,APPOINTMENT属于患者和护士。
然而,我还希望护士能够找到患者是否出现的方法。我在迁移中实现了这样的:
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
但这不是我想要的。我希望护士能够修改这种关联,并阻止患者改变任何事情。
我不应该为此使用丰富的关联吗?
答案 0 :(得分:2)
我假设您的问题是关于如何使用这些关联。您可以在保留约会后调用和修改约会记录,如下所示:
# current_nurse is the nurse using the system and reporting
appt = current_nurse.appointments.where(:patient_id => params[:patient_id]).first
appt.update_attribute :present, true
为防止患者访问和修改约会,您需要一种身份验证机制,例如devise。然后只授予护士访问系统的权限。