ruby on rails中Model的关联详解
发布时间 - 2026-01-11 02:32:46 点击率:次前言:
在学习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
以上就是本文给大家分享的全部内容了,给出的示例也非常的简单易懂,希望大家能够喜欢。
# ruby
# on
# rails
# 教程
# model关联
# 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开发环境
# 小王
# 多个
# 是由
# 的是
# 有一个
# 可以说
# 中有
# 小明
# 这是
# 知道了
# 关联关系
# 也不
# 成了
# 放在
# 都要
# 就能
# 是这样
# 会在
# 这句话
# 这样做
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
python中快速进行多个字符替换的方法小结
如何有效防御Web建站篡改攻击?
详解CentOS6.5 安装 MySQL5.1.71的方法
Android 常见的图片加载框架详细介绍
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
如何撰写建站申请书?关键要点有哪些?
php打包exe后无法访问网络共享_共享权限设置方法【教程】
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
jQuery 常见小例汇总
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
非常酷的网站设计制作软件,酷培ai教育官方网站?
如何在云主机上快速搭建多站点网站?
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
Laravel模型事件有哪些_Laravel Model Event生命周期详解
JS中对数组元素进行增删改移的方法总结
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
深圳网站制作的公司有哪些,dido官方网站?
微信h5制作网站有哪些,免费微信H5页面制作工具?
轻松掌握MySQL函数中的last_insert_id()
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
详解Android——蓝牙技术 带你实现终端间数据传输
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
如何在搬瓦工VPS快速搭建网站?
Python文本处理实践_日志清洗解析【指导】
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
Bootstrap整体框架之JavaScript插件架构
如何在香港服务器上快速搭建免备案网站?
Thinkphp 中 distinct 的用法解析
Laravel如何实现事件和监听器?(Event & Listener实战)
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
如何快速完成中国万网建站详细流程?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
香港服务器如何优化才能显著提升网站加载速度?
Android GridView 滑动条设置一直显示状态(推荐)
如何用美橙互联一键搭建多站合一网站?
黑客如何利用漏洞与弱口令入侵网站服务器?
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
微信小程序 scroll-view组件实现列表页实例代码
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
制作公司内部网站有哪些,内网如何建网站?
HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】
如何在新浪SAE免费搭建个人博客?
Laravel如何处理文件下载请求?(Response示例)
在centOS 7安装mysql 5.7的详细教程

