国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > Ruby > 正文

ruby on rails中Model的關(guān)聯(lián)詳解

2020-10-29 19:34:06
字體:
供稿:網(wǎng)友

前言:
在學(xué)習(xí)model關(guān)聯(lián)之前,首先要牢記一下幾點(diǎn):
1.關(guān)聯(lián)關(guān)系,兩端都要寫好,否則會(huì)出現(xiàn)初學(xué)者看不懂的錯(cuò)誤。而且對(duì)于理解代碼,非常有好處。
2.model的名字是單數(shù),controller是復(fù)數(shù)。
3.blong_to后面必須是單數(shù),而且必須是小寫。has_many后面必須是復(fù)數(shù)。

一:一對(duì)多

例如:
王媽媽有兩個(gè)孩子,小明和小亮。可以說,王媽媽,有多個(gè)孩子。也可以說:小明,有一個(gè)媽媽;小王,有一個(gè)媽媽。我們一般在設(shè)計(jì)表的時(shí)候,是這樣設(shè)計(jì)的:
mothers表中id和name
sons表中有id和name
為了增加邏輯關(guān)系,主外鍵關(guān)系,會(huì)在多的一方,增加一列,所以sons表中有三列,id和name和mother_id(對(duì)應(yīng)了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

解釋:一個(gè)媽媽又多個(gè)孩子,一個(gè)兒子屬于一個(gè)媽媽。
我們?cè)趓ails console可以測(cè)試下:
xiao_wang = Son.first 
mom = xiaowang.mother

這個(gè) .mother 方法就是由 class Son的belongs_to :mother這句話生成的。
也就是相當(dāng)于轉(zhuǎn)換成了一下的sql語句:

select * from mothers   join sons   on sons.mother_id = mothers.id   where sons.id = 1

詳細(xì)解釋:

A:belongs_to :mother
B:belongs_to :mother, :class => 'Mother', :foreign_key => 'mother_id'
A=B

這個(gè)就是Rails最典型的根據(jù)慣例來編程,聲明哪個(gè)表對(duì)應(yīng)的是哪個(gè)class,再在class之間聲明好關(guān)聯(lián)關(guān)系。
1.belongs_to :mother, rails就能判斷出: mothers 表,是一的那一端。 而當(dāng)前class 是: "class Son", 那么rails 就知道了 兩個(gè)表的對(duì)應(yīng)關(guān)系。
2.:class => 'Mother', 表示, 一的那一端, 對(duì)應(yīng)的model class是Mother. 根據(jù)rails的慣例, Mother model對(duì)應(yīng)的是 數(shù)據(jù)庫中的 mothers 表。
3.:foreign_key => 'mother_id', rails就知道了, 外鍵是 'mother_id'. 而一對(duì)多關(guān)系中, 外鍵是保存在 多的那一端(也就是 sons, 所以說,在 sons表中, 必須有一個(gè)列, 叫做: mother_id )
所以, 這個(gè)復(fù)雜的SQL 條件就齊備了, 可以生成了。
上面的ruby代碼,配置好之后, 就可以這樣調(diào)用:

son = Son.firstson.mother # .mother方法, 是由 class Son 中的 belongs_to 產(chǎn)生的。mother = Mother.firstmother.sons  # .sons 方法, 是由 class Mother 中的 hash_many 產(chǎn)生的。

二:一對(duì)一,比較簡單,也不常用,這里不介紹。(老公和老婆)

三:多對(duì)多

例如:
一個(gè)學(xué)生,有多個(gè)老師,(學(xué)習(xí)了多門課程)
一個(gè)老師,可以教多個(gè)孩子(教一門課程,但是有好多學(xué)生來聽這個(gè)課程)
我們往往會(huì)這樣做:
students有id和name兩個(gè)字段
teachers有id和name兩個(gè)字段
放在任何一個(gè)表中都不合適,這是我們需要一張中間表,也就是橋梁表。
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 相當(dāng)于
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

以上就是本文給大家分享的全部內(nèi)容了,給出的示例也非常的簡單易懂,希望大家能夠喜歡。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
麻豆视频国产| 美女av在线播放| 亚洲成人在线播放| 精品美女在线观看视频在线观看| 91午夜在线| 伊人国产在线看一| 四虎国产精品永久| 欧美日韩亚洲第一页| 黄色三级视频在线观看| 91sp网站在线观看入口| 国产高清一级片| аⅴ成人天堂中文在线| 中文字幕av中文字幕| 亚洲网站视频在线观看| 国产有码在线| 福利在线观看| 在线天堂视频| 天堂在线看视频| 精品一区二区三区免费站| h网址在线观看| 国产天堂在线播放视频| 在线色视频观看| 中文字幕高清av| 欧美另类在线视频| 国产国语**毛片高清视频| 免费观看久久久久| 国产馆av播放| 狠狠色综合久久婷婷| 永久免费在线观看| 国产小视频在线观看| 精品成人一区二区三区免费视频| 开心婷婷激情五月| gogogogo高清视频在线| 2021av在线| 国产污视频在线| 国产在线视频网站| eeuss影影院www在线播放| 国产黄色小视频| 五月婷婷丁香激情| 狠狠插狠狠操| 久久久久久77777| 日本欧洲一区| www.三区| 另类高清dbsm日本tvav| 亚洲人成电影| 国产精品178页| 国产精美视频| 国产福利三区| 在线一区观看| www.91av| 国产在线你懂得| 国产污污在线观看| 国产www.大片在线| 亚洲夜夜综合| 欧美性猛交xxxx免费看蜜桃| 免费av在线| 国产在线高潮| 国产视频2区| 2021天堂中文幕一二区在线观| 国产人成精品| 国产精品白浆视频免费观看| 国产精品69一区二区三区| 在线中文字幕第一页| 欧美亚洲天堂| 国产一区二区三区美女秒播| 91在线网址| 牛牛热在线视频| 国产福利热线视频| www亚洲天堂| 午夜av在线免费观看| 国产蜜臀在线| 国产区视频在线| 午夜影院在线免费观看| 国产免费自拍视频| ·天天天天操| 在线观看av的网站| 国产免费自拍视频| 在线中文字幕视频观看| 国内a∨免费播放| 精品麻豆一区二区三区 | 国产中文字幕网| 中文字幕一区免费| xxxxx中文字幕| 69久久久久| 综合激情丁香| 成人免费一区二区三区视频网站| 91嫩草在线播放| 中文字幕乱在线伦视频乱在线伦视频| 在线亚洲不卡| 国产一级黄色| 开心激情五月婷婷| 天天操夜夜添| 亚洲wwwwww| 怡红院av在线| 精品全国在线一区二区| 国产人成高清视频观看| 在线91av| 国产午夜三区视频在线| 国产在线观看18| 青草青在线视频| 亚洲va国产日韩欧美精品色婷婷| 精精国产xxxx视频在线| 91欧洲在线视精品在亚洲| 老司机在线视频二区| 日本一二三区视频免费高清| 在线免费观看污| 亚洲最新永久在线观看| 精品偷拍激情视频在线观看| 91极品在线| 在线视频中文字幕久| 91黄色在线| 在线观看的av| 天天艹天天操| 国产69精品久久久久孕妇国产69久久| 久久亚洲天堂| 国产精品综合久久久久| 国产小视频免费在线网址| 中文字幕在线免费观看| 国产美女视频一区二区三区| 毛片网站在线观看| 国产乱精品一区二区三区| 国产有码在线| 国产一二区视频| 在线观看av中文| 久久五月精品中文字幕| 国产三级视频在线看| 伊人影院在线观看| 国产美女福利在线| 精品一区二区91| 国产永久在线观看| 国产精品视频一区二区免费不卡 | 国产无遮挡又黄又爽免费网站| 国产午夜视频在线观看| 中文日本在线观看| 九九热视频精品在线观看| 国产日韩欧美一区二区三区视频| 精品国产高清a毛片无毒不卡| 欧美色第一页| 在线免费看黄av| 午夜不卡视频| 日韩中文字幕久久久经典网| 国产网站在线免费观看| 超碰免费在线| 亚洲成人电视网| 国产黄在线观看免费观看不卡| 在线色视频观看| 国产日韩网站| 午夜视频在线看| 九色视频网站| www在线观看播放免费视频日本| **三级三级97片毛片| 超碰在线97国产| 亚洲va国产日韩欧美精品色婷婷| 国产黄视频网站| 最新中文字幕在线视频| 超碰在线网址| 人成在线免费视频| 亚洲图区综合| 夜夜操天天干| 在线三级中文| 国产精品186在线观看在线播放| 九九热在线观看视频| eeuss影院在线播放| 精品999视频| 在线观看国产视频| av在线首页| 黄色在线视频观看网站| 久久国产精品久久久久久小说| 香蕉视频在线观看网站| av在线免费播放| 久久精品视频观看| 国产小视频在线高清播放| 国产三级视频在线看| 国产福利在线视频| 中文天堂av| 午夜影院在线免费观看| 日本一级理论片在线大全| av在线免费观看网| 福利视频在线导航| 国产福利视频在线| 超碰97在线免费观看| 国产毛片毛片毛片| 国产成人亚洲欧美电影| 伊人网在线免费观看| 免费a在线看| 国产二区三区在线| 欧美a免费在线| 国产视频二区三区| 青草在线视频在线观看| 大香伊人中文字幕精品| 国产一级电影网| 永久免费在线观看| 国产精品一卡二卡三卡| 国产大学生粉嫩无套流白浆| www在线视频| 国产高清在线| 国产有码在线| 四虎影视成人永久免费观看视频| 中文字幕在线观看播放| 伊人国产在线看一|