前言:
在學習model關聯之前,首先要牢記一下幾點:
1.關聯關系,兩端都要寫好,否則會出現初學者看不懂的錯誤。而且對于理解代碼,非常有好處。
2.model的名字是單數,controller是復數。
3.blong_to后面必須是單數,而且必須是小寫。has_many后面必須是復數。
一:一對多
例如:
王媽媽有兩個孩子,小明和小亮。可以說,王媽媽,有多個孩子。也可以說:小明,有一個媽媽;小王,有一個媽媽。我們一般在設計表的時候,是這樣設計的:
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
以上就是本文給大家分享的全部內容了,給出的示例也非常的簡單易懂,希望大家能夠喜歡。
您可能感興趣的文章:- Windows下Ruby on Rails開發環境安裝配置圖文教程
- ruby on rails 代碼技巧
- 攻克CakePHP(PHP中的Ruby On Rails框架)圖文介紹
- 在阿里云 (aliyun) 服務器上搭建Ruby On Rails環境
- 在Ruby on Rails中使用AJAX的教程
- CentOS中配置Ruby on Rails環境
- win7安裝ruby on rails開發環境