ruby on rails中Model的关联详解
前言:
在学习model关联之前,首先要牢记一下几点:
1.关联关系,两端都要写好,否则会出现初学者看不懂的错误。而且对于理解代码,非常有好处。
2.model的名字是单数,controller是复数。
3.blong_to后面必须是单数,而且必须是小写。has_many后面必须是复数。
一:一对多
例如:
王妈妈有两个孩子,小明和小亮。可以说,王妈妈,有多个孩子。也可以说:小明,有一个妈妈;小王,有一个妈妈。我们一般在设计表的时候,是这样设计的:
mothers表中id和name
sons表中有id和name
为了增加逻辑关系,主外键关系,会在多的一方,增加一列,所以sons表中有三列,id和name和mother_id(对应了mothers表的id)
普通SQL:
selecttest_associate.mothers.namefromtest_associate.mothersinnerjointest_associate.sonsonsons.mother_id=mothers.idwheresons.name='小李'
ruby代码:
classMother has_many:sons end classSon belongs_to:mother end
解释:一个妈妈又多个孩子,一个儿子属于一个妈妈。
我们在railsconsole可以测试下:
xiao_wang=Son.first
mom=xiaowang.mother
这个.mother方法就是由classSon的belongs_to:mother这句话生成的。
也就是相当于转换成了一下的sql语句:
select*frommothers joinsons onsons.mother_id=mothers.id wheresons.id=1
详细解释:
A:belongs_to:mother
B:belongs_to:mother,:class=>'Mother',:foreign_key=>'mother_id'
A=B
这个就是Rails最典型的根据惯例来编程,声明哪个表对应的是哪个class,再在class之间声明好关联关系。
1.belongs_to:mother,rails就能判断出:mothers表,是一的那一端。而当前class是:"classSon",那么rails就知道了两个表的对应关系。
2.:class=>'Mother',表示,一的那一端,对应的modelclass是Mother.根据rails的惯例,Mothermodel对应的是数据库中的mothers表。
3.:foreign_key=>'mother_id',rails就知道了,外键是'mother_id'.而一对多关系中,外键是保存在多的那一端(也就是sons,所以说,在sons表中,必须有一个列,叫做:mother_id)
所以,这个复杂的SQL条件就齐备了,可以生成了。
上面的ruby代码,配置好之后,就可以这样调用:
son=Son.first son.mother#.mother方法,是由classSon中的belongs_to产生的。 mother=Mother.first mother.sons#.sons方法,是由classMother中的hash_many产生的。
二:一对一,比较简单,也不常用,这里不介绍。(老公和老婆)
三:多对多
例如:
一个学生,有多个老师,(学习了多门课程)
一个老师,可以教多个孩子(教一门课程,但是有好多学生来听这个课程)
我们往往会这样做:
students有id和name两个字段
teachers有id和name两个字段
放在任何一个表中都不合适,这是我们需要一张中间表,也就是桥梁表。
lessons有id和name和student_id和teacher_id
原始SQL:
selectteachers.*,students.*,lessons.* fromlessonsfromteachers, jointeachers onlessons.teacher_id=teachers.id joinstudents onlessons.student_id=students.id wherestudents.name='小王'
Ruby代码:
classStudent has_many:lessons has_many:teachers,:through=>:lessons end
提示:has_many:teachers,:through=>:lessons相当于
has_many:teachers,:class=>'Teacher',:foreign_key=>'teacher_id',:throught=>:lessons
classTeachers
has_many:lessons
has_many:students,:through=>:lessons
end
查看小王的老师有哪些,同上面的原始SQL语句。
Student.find_by_name('小王').teachers
以上就是本文给大家分享的全部内容了,给出的示例也非常的简单易懂,希望大家能够喜欢。