Ruby on rails开发从头来(五十八)- ActiveRecord基础(自关联) - 编程入门网
作者 佚名技术
来源 NET编程
浏览
发布时间 2012-06-14
Ruby on rails开发从头来(五十八)- ActiveRecord基础(自关联)时间:2011-12-04 博客园 Cure或许存在这样的情况,在一个表中,一条记录关联到表中的另一条记录,例如,公司中的每个雇员都有上级和下级,而他们同时又是雇员,在Rails中你可以这样使用Employee类: class Employee < ActiveRecord::Base belongs_to :manager, :class_name => "Employee", :foreign_key => "manager_id" belongs_to :mentor, :class_name => "Employee", :foreign_key => "mentor_id" has_many :mentored_employees, :class_name => "Employee", :foreign_key => "mentor_id" has_many :managed_employees, :class_name => "Employee", :foreign_key => "manager_id" end 让我们使用一些数据,这里雇员Clem和Dawn都有上级和下级: Employee.delete_all adam = Employee.create(:id => 1, :name => "Adam") beth = Employee.create(:id => 2, :name => "Beth") clem = Employee.new(:name => "Clem") clem.manager = adam clem.mentor = beth clem.save! dawn = Employee.new(:name => "Dawn") dawn.manager = adam dawn.mentor = clem dawn.save! 现在我们可以通过关联,来回答“X的下属是谁?”,“Y的上级是谁?”。 p adam.managed_employees.map {|e| e.name} # => [ "Clem", "Dawn" ] p adam.mentored_employees # => [] p dawn.mentor.name # => "Clem" |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: Ruby on rails开发从头来(三十九)- ActiveRecord基础(访问属性) - 编程入门网下一篇: Ruby on rails开发从头来(四十七)- ActiveRecord基础(强大的find方法) - 编程入门网
关于Ruby on rails开发从头来(五十八)- ActiveRecord基础(自关联) - 编程入门网的所有评论