首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Laravel Eloquent 模型关联关系(下)

在前面两篇教程中,学院君陆续给大家介绍了 Eloquent 模型类支持的七种关联关系,通过底层提供的关联方法,我们可以快速实现模型间的关联,并且进行关联查询。...Eloquent 提供了这种同步机制帮助我们更新子模型时触发父模型的更新时间 updated_at 字段值更新,要让该机制生效,需要在子模型中配置 $touches 属性: // 要触发更新的父级关联关系...(31); $comment->content = 'Laravel学院致力于提供优质Laravel中文学习资源'; $comment->save(); 再次查看评论模型及对应文章模型数据,可以看到文章模型的更新事件和评论模型的更新时间已经一致了...: 结语 好了,关于关联关系我们就介绍到这里,我们分了三篇的篇幅来介绍 Eloquent 模型的管理关系,回顾一下,主要包含以下内容: 七种关联关系的定义:一对一、一对多、多对多、远层一对多、一对一的多态关联...希望你看完学院君的这一系列教程可以了解并完全掌握 Eloquent 模型的定义和使用,有什么问题,欢迎随时与我交流。

19.5K30

Laravel Eloquent 模型关联关系详解(上)

到目前为止,我们介绍的所有 Eloquent 模型操作都是针对单表的,接下来我们将花三篇左右的篇幅来给大家介绍如何在 Eloquent 模型类中建立模型之间的各种关联关系,以及如何实现关联查询和更新。...你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认的约定。...为什么我们不需要指定 Laravel 就能完成这种关联呢,这是因为如果没有指定 $foreignKey,Eloquent 底层会通过如下方法去拼接: public function getForeignKey...建立相对的关联关系 与一对一一样,我们可以在文章模型中建立与用户模型之间的相对关联关系,而且这种使用场景很普遍,比如在文章详细页或列表页显示文章作者信息。...建立相对的关联关系 与之前的关联关系一样,多对多关联也支持建立相对的关联关系,而且由于多对多的双方是平等的,不存在谁归属谁的问题,所以建立相对关联的方法都是一样的,我们可以在 Tag 模型中通过 belongsToMany

9.8K40
您找到你想要的搜索结果了吗?
是的
没有找到

详解Laravel设置多态关系模型别名的方式

作为 Laravel 的重度使用者肯定都对多态关系不默生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型关系就是 多态多对多(Many To Many (Polymorphic...docs/6.x/eloquent-relationships#custom-polymorphic-types 我们可以将这个定义写到 AppServiceProvider 中,但是有一个非常严重的问题...我已经至少出现这个问题 3 次了,所以我一直在纠结有没有更好的方法,今天突然灵机一动,实现了一个看起来似乎是一个不错的方式,分享给大家。...UseTableNameAsMorphClass { public function getMorphClass() { return $this- getTable(); } } 然后在我们需要用到关系类型的模型中引入它即可...总结 以上所述是小编给大家介绍的Laravel设置多态关系模型别名的方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对ZaLou.Cn网站的支持!

1.9K21

Laravel 多态关系的表单验证

相信大家使用 Laravel 开发应用的时候都会有评论模块吧,而且我们通常将该模块设计为多态关系(如果你对这个关系还不明白的话,请赶紧打开 Laravel 文档数据库关系章节复习一遍吧!)。...先看看我们的数据库结构: id commentable_id commentable_type body 那么遇到一个问题,如果写入数据呢?...一般来讲有两种方式,而我们通常用的一种是从父模型使用关系写入,比如我们有一个 App\Thread 类,它里面对评论的关系是这样的: class Thread {    public function..., ]); 其实不管哪一种,我们都少不了表单验证,而且无论使用任何一种我们都得需要传入两个关键参数: 类型与 id,那就涉及到一个问题,如何验证呢?...是不是简单很多,而且这样验证规则还能重用在其它同类多态关系的地方哦。 这样就结束了么?没有! 我们上面的拓展验证规则的写法没有感觉有些粗暴么?是时候规范一下了。

2.1K40

ER图转关系模型_实体关系图变关系模型

(1)实体类型的转换 将每个实体类型转换成一个关系模式,实体的 属性 即为关系的 属性,实体标识符即为关系的键。...(2)联系类型的转换 实体间的关系是1对1 在实体类型转换成两个关系模式中的任意一个关系模式的属性中加入另一个关系模式的键和联系类型的属性。...实体间的联系是1对N 则在N端实体类型转换成的关系模式中加入1端 实体类主键。 如实体间的联系是M对N 单独将 联系类型 也转换成关系模式。将M和N端的主键都加进去。...示例:该ER图转换为关系模型 商店 和 职工是一对多关系,一个商店有多个职工,而一个职工只能属于一家商店;即职工是多端,在职工的关系模型中加入商店的主键,作为职工关系模型的外键 商店(商店编号,商店名...,地址) 职工(职工编号,姓名,性别,商店编号) 商店和商品是多对多,可以将二者的联系类型 销售 也转换成关系模型 商品(商品号,商品名,规格,单价) 销售(商店编号,商品号,月销售量) 一般主键加下划线

2.4K60

django 模型关系

模型关系 关系数据库的威力体现在表之间的相互关联,Django提供了三种最常见的数据库关系:多对一 (many-to-one),多对多(many-to-many),一对一(one-to-one)...多对一关系 多对多关系 一对一关系 多对一 django是使用django.db.models.ForeignKey 定义多对一关系 ForeignKey需要一个位置参数来指定本Model关联的Model...所在的模型) 如果模型有一个ForeignKey,那么该ForeignKey 所指的模型实例可以通过一个管理器返回前一个有ForeignKey的模型的所有实例。...如果不仅仅需要知道两个Model之间是多对多的关系,还需要知道这个关系的更多信息,比如Person和Group是多对多的关系,每个person可以在多个group里,那么group里可以有多个person...来实现的,被关联的Model会被加上 Unique的限制,OneToOneField要一个位置参数,与模型关- 联的类 当某个对象想扩展自另一个对象时,最常用的方式就是在这个对象的主键上添加一对一关系

1.4K30

一种 Laravel 中简单设置多态关系模型别名的方式

作为 Laravel 的重度使用者肯定都对多态关系不陌生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型关系就是多态多对多(Many To Many (Polymorphic...docs/6.x/eloquent-relationships#custom-polymorphic-types 我们可以将这个定义写到 AppServiceProvider 中,但是有一个非常严重的问题...我已经至少出现这个问题 3 次了,所以我一直在纠结有没有更好的方法,今天突然灵机一动,实现了一个看起来似乎是一个不错的方式,分享给大家。...UseTableNameAsMorphClass { public function getMorphClass() { return $this->getTable(); } } 然后在我们需要用到关系类型的模型中引入它即可...References [1] 多态多对多(Many To Many (Polymorphic)): https://laravel.com/docs/6.x/eloquent-relationships

2.7K10

关系模型(重要)

关系数据模型的数据结构,每个关系的数据结构是一张规范的二维表 术语: 关系(Relation):一个关系对应通常说的一张表 元组(Tuple):表中的一行即为一个元组 属性(Attribute):表中的一列即为一个属性...键(key):表中的某个属性组,它可以唯一确定一个元组 域(domain):属性的取值范围 分量:元组中的一个属性值 关系模式:对关系的描述,一般表示为 :关系名(属性1,属性2,……,属性n) 优点...: l 建立在严格的数学概念的基础上的 l 关系模型的概念单一,无论实体还是实体之间的联系都用关系(二维表)来表示,对数据的检索和更新也是关系,所以其数据结构简单、清晰、用户易懂易用。...l 关系模型的存取路径对用户透明,从而具有更高的数据独立性,更好的安全保密性 缺点: 由于存取路径对用户透明,查询效率往往不如格式化数据模型,为了提高性能,DBMS必须对用户的查询请求进行优化。

52620

MySQL·关系模型

关系模型 外键 在 students 表中,通过 class_id 的字段,可以把数据与另一张表关联起来,这种列称为外键。...通过定义外键约束,关系数据库可以保证无法插入无效的数据。即如果 classes 表不存在 id=99 的记录,students 表就无法插入 class_id=99 的记录。...索引 索引是关系数据库中对某一列或多个列的值进行预排序的数据结构。通过使用索引,可以让数据库系统不必扫描整个表,而是直接定位到符合条件的记录,这样就大大加快了查询速度。...在设计关系数据表的时候,看上去唯一的列,例如身份证号、邮箱地址等,因为他们具有业务含义,因此不宜作为主键。但是,这些列根据业务要求,又具有唯一性约束:即不能出现两条记录存储了同一个身份证号。...无论是否创建索引,对于用户和应用程序来说,使用关系数据库不会有任何区别。

78430

3分钟短文:说说Laravel模型中还算常用的2个“关系

引言 上一章我们介绍了比较简单的laravel模型关联关系中的一对一,介绍了关联操作方法。...belongsTo 关系 正好像对于一个词语,找到对应的反义词,或者说有一个图片,找到其镜像图片这样的。 有作用力,就有反作用力。一对一关系模型中,A有一个B,则反过来,B属于一个A。...在模型Profile中添加对应到User模型关系: class Profile extends Model { public function user() { return...类中我们声明了 user() 方法用于关系用户模型, 所以此处链式调用 user 属性,返回的是一个 App\User 对象实例,其包含 User 模型的所有属性, 因此 email 属性也相应返回数据库内的字段值...我们使用State模型状态有多个Event事件这个场景,演示一下一对多关系的声明,以及应用。

2.1K31

Laravel多对多关系详解【文章 - 标签】

前言 今天弄了一天的关于文章的功能,其中主要卡在文章与标签的多对多的关系纠结中。卡了半天,终于算是解决了,不是很完美,但可以。 新建迁移文件 多对多的关系中,需要三张表。...两张主体表、一张这两张表的关系表。...这是我是文章表【articles】、标签表【tags】以及关系表【article_tag】 其中关系的命名是[article_tag]而不是tag_article 因为laravel默认是以字母升序排列...新建文章表 php artisan make:model Model/Article -m 我是新建模型的时候就顺带穿件迁移表了。...新建标签表 php artisan make:model Model/Tag -m 我是新建模型的时候就顺带穿件迁移表了。 ? 可以看出没有外键。

1.8K00
领券