gpt4 book ai didi

ruby on rails中Model的关联详解

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 26 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章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

?
1
select test_associate.mothers. name from test_associate.mothers inner join test_associate.sons on sons.mother_id = mothers.id where sons. name = '小李'

ruby代码:

?
1
2
3
4
5
6
7
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语句:

?
1
2
3
4
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代码,配置好之后, 就可以这样调用:

?
1
2
3
4
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:

?
1
2
3
4
5
6
7
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代码

?
1
2
3
4
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语句.

?
1
Student.find_by_name( '小王' ).teachers

以上就是本文给大家分享的全部内容了,给出的示例也非常的简单易懂,希望大家能够喜欢.

原文链接:http://www.jianshu.com/p/ed91f63d9ae4 。

最后此篇关于ruby on rails中Model的关联详解的文章就讲到这里了,如果你想了解更多关于ruby on rails中Model的关联详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com