假设我们有三个模型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
但这不是我想要的.我希望护士能够修改这种关联,并锁定患者不要改变任何东西.
我不应该为此使用丰富的协会吗?
最佳答案 我假设您的问题是关于如何使用这些关联.您可以在保留约会后调用和修改约会记录,如下所示:
# 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.然后,只授予护士访问系统的权限.