详解ruby on rails中Model的关联
大多数网站在建站的时候都会考虑自己的安全性,而验证码检测已成为一个必不可少的过程,Ruby的验证代码实现起来更简单、更方便,本文是爱站技术频道小编为大家带来的详解ruby on rails中Model的关联,一起来学习吧!
一:一对多
例如:
王妈妈有两个孩子,小明和小亮。可以说,王妈妈,有多个孩子。也可以说:小明,有一个妈妈;小王,有一个妈妈。我们一般在设计表的时候,是这样设计的:
mothers表中id和name
sons表中有id和name
为了增加逻辑关系,主外键关系,会在多的一方,增加一列,所以sons表中有三列,id和name和mother_id(对应了mothers表的id)
普通SQL:
select test_associate.mothers.name from test_associate.mothers inner join test_associate.sons on sons.mother_id = mothers.id where sons.name = '小李'
ruby代码:
class Mother has_many :sons end class Son belongs_to :mother end
解释:一个妈妈又多个孩子,一个儿子属于一个妈妈。
我们在rails console可以测试下:
xiao_wang = Son.first
mom = xiaowang.mother
这个 .mother 方法就是由 class Son的belongs_to :mother这句话生成的。
也就是相当于转换成了一下的sql语句:
select * from mothers join sons on sons.mother_id = mothers.id where sons.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 是: "class Son", 那么rails 就知道了 两个表的对应关系。
2.:class => 'Mother', 表示, 一的那一端, 对应的model class是Mother. 根据rails的惯例, Mother model对应的是 数据库中的 mothers 表。
3.:foreign_key => 'mother_id', rails就知道了, 外键是 'mother_id'. 而一对多关系中, 外键是保存在 多的那一端(也就是 sons, 所以说,在 sons表中, 必须有一个列, 叫做: mother_id )
所以, 这个复杂的SQL 条件就齐备了, 可以生成了。
上面的ruby代码,配置好之后, 就可以这样调用:
son = Son.first son.mother # .mother方法, 是由 class Son 中的 belongs_to 产生的。 mother = Mother.first mother.sons # .sons 方法, 是由 class Mother 中的 hash_many 产生的。
二:一对一,比较简单,也不常用,这里不介绍。(老公和老婆)
三:多对多
例如:
一个学生,有多个老师,(学习了多门课程)
一个老师,可以教多个孩子(教一门课程,但是有好多学生来听这个课程)
我们往往会这样做:
students有id和name两个字段
teachers有id和name两个字段
放在任何一个表中都不合适,这是我们需要一张中间表,也就是桥梁表。
lessons有id和name和student_id和teacher_id
原始SQL:
select teachers.*, students.*, lessons.* from lessons from teachers , join teachers on lessons.teacher_id = teachers.id join students on lessons.student_id = students.id where students.name = '小王'
Ruby代码:
class Student 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
class Teachers
has_many :lessons
has_many :students, :through => :lessons
end
查看小王的老师有哪些,同上面的原始SQL语句。
Student.find_by_name('小王').teachers
以上就是详解ruby on rails中Model的关联,建议大家收藏该文章,相信这里的内容是对你有帮助的,也建议你经常来爱站技术频道逛一逛,相信有用的信息就在这里。
上一篇:Ruby实现的图片滤镜算法代码
下一篇:Ruby中数组的使用方法