麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Ruby > 正文

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

2020-02-24 15:36:14
字體:
供稿:網(wǎng)友

大多數(shù)網(wǎng)站在建站的時候都會考慮自己的安全性,而驗證碼檢測已成為一個必不可少的過程,Ruby的驗證代碼實現(xiàn)起來更簡單、更方便,本文是武林技術(shù)頻道小編為大家?guī)淼脑斀?a target="_blank">ruby on rails中Model的關(guān)聯(lián),一起來學(xué)習(xí)吧!

一:一對多

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

解釋:一個媽媽又多個孩子,一個兒子屬于一個媽媽。
我們在rails console可以測試下:
xiao_wang = Son.first?
mom = xiaowang.mother

這個 .mother 方法就是由 class Son的belongs_to :mother這句話生成的。
也就是相當于轉(zhuǎn)換成了一下的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最典型的根據(jù)慣例來編程,聲明哪個表對應(yīng)的是哪個class,再在class之間聲明好關(guān)聯(lián)關(guān)系。
1.belongs_to :mother, rails就能判斷出: mothers 表,是一的那一端。 而當前class 是: "class Son", 那么rails 就知道了 兩個表的對應(yīng)關(guān)系。
2.:class => 'Mother', 表示, 一的那一端, 對應(yīng)的model class是Mother. 根據(jù)rails的慣例, Mother model對應(yīng)的是 數(shù)據(jù)庫中的 mothers 表。
3.:foreign_key => 'mother_id', rails就知道了, 外鍵是 'mother_id'. 而一對多關(guān)系中, 外鍵是保存在 多的那一端(也就是 sons, 所以說,在 sons表中, 必須有一個列, 叫做: mother_id )
所以, 這個復(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)生的。

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

三:多對多

例如:
一個學(xué)生,有多個老師,(學(xué)習(xí)了多門課程)
一個老師,可以教多個孩子(教一門課程,但是有好多學(xué)生來聽這個課程)
我們往往會這樣做:
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的關(guān)聯(lián),建議大家收藏該文章,相信這里的內(nèi)容是對你有幫助的,也建議你經(jīng)常來武林技術(shù)頻道逛一逛,相信有用的信息就在這里。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 羞羞的视频免费观看 | 色婷婷一区二区三区 | 国产99久久精品一区二区300 | 成人一级视频在线观看 | av在线播放免费观看 | 亚洲精品一区二区三区在线看 | 国产成人高潮免费观看精品 | 欧美亚洲黄色 | 欧美成人黄色小视频 | 亚洲精品欧美在线 | 国产精品成人免费一区久久羞羞 | 国产一区二区免费在线观看 | 国产精品久久久久久久模特 | 国产一级性生活视频 | 最新国产毛片 | 91香蕉国产亚洲一区二区三区 | 精品一区二区久久久久久按摩 | 亚洲国产网站 | 性 毛片 | 久久精品国产99久久久古代 | 一级免费毛片 | 羞羞色在线观看 | 91av在线免费播放 | 欧美不卡视频在线观看 | 亚洲精品久久久久久久久久久 | 激情综合在线 | 日韩一级电影在线观看 | 日韩黄a| 深夜免费视频 | 精品久久久久久久久久久aⅴ | 日韩黄色片在线观看 | 日本人乱人乱亲乱色视频观看 | 亚洲二区三区在线 | 亚洲第五色综合网 | 久久艳片| 国产激情网 | 国产亚洲精品久久久久久网站 | av黄色片网站 | 亚洲精品tv久久久久久久久久 | 成人黄色短视频在线观看 | 国产精品免费一区二区三区四区 |