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

Laravel Eloquent 模型关联关系(下)

今天我们将在定义好模型关联基础上进行关联查询、插入更新操作,看看如何借助模型关联提高代码可读性并提高编码效率。...还是以文章和标签为例,要将两个本来没有关联关系记录绑定起来,可以通过 attach 方法实现: $post = Post::findOrFail(1); $tag = Tag::findOrFail(...(31); $comment->content = 'Laravel学院致力于提供优质Laravel中文学习资源'; $comment->save(); 再次查看评论模型及对应文章模型数据,可以看到文章模型更新事件评论模型更新时间已经一致了...: 结语 好了,关于关联关系我们就介绍到这里,我们分了三篇篇幅来介绍 Eloquent 模型管理关系,回顾一下,主要包含以下内容: 七种关联关系定义:一对一、一对多、多对多、远层一对多、一对一多态关联...、一对多多态关联、多对多多态关联; 以上关联关系查询,主要包含两种方式:懒惰式加载渴求式加载; 基于关联查询构架复杂查询对查询结果进行过滤; 关联模型更新、插入删除操作。

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

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

到目前为止,我们介绍所有 Eloquent 模型操作都是针对单表,接下来我们将花三篇左右篇幅来给大家介绍如何在 Eloquent 模型类中建立模型之间各种关联关系,以及如何实现关联查询更新。...准备好数据表之后,接下来,我们来通过模型类建立 users 表 user_profiles 表之间关联,Eloquent 模型类底层提供了相应 API 方法帮助我们建立模型之间关联。...你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认约定。...第二个参数是当前模型类所属表外键,在本例中是 user_profiles 表 user_id 字段,拼接规则 hasOne 那里类似,只不过这里是基于第四个参数关联关系名称 $relation:... hasOne 方法一样,hasMany 方法底层也对如何建立关联关系做了约定,而且 hasMany 方法 hasOne 方法签名一样: public function hasMany($related

9.8K40

Laravel关系模型指定条件查询方法

对于关系模型来说,有时候我们需要甄别关联后结果,例如,班级学生是一对多关联,我现在查询班级,但是想只显示正常状态,即状态为1学生,因为有的学生从这个班级里面删除了,状态是4,那么我们在查询时候就可以使用如下语法...: 1、定义关联关系: Class模型: public function learners() { return $this- belongsToMany('App\Models\Customer'..., 'learner_relation', 'class_id', 'learner_id'); } Customer模型: public function learnerclasses() { return...learner_relation.status', 1) - orderBy('learner_relation.create_time', 'desc'); }, ]) - find($id); 然后得到结果就是我们想要正常学生...以上这篇Laravel关系模型指定条件查询方法就是小编分享给大家全部内容了,希望能给大家一个参考。

1.8K41

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

作为 Laravel 重度使用者肯定都对多态关系不默生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型关系就是 多态多对多(Many To Many (Polymorphic...)) 如果我们给 ID 为 1 文章打上两个标签,数据库标签关系存储结果就是这样子: select * from taggables; +--------+-------------+---...实现目标 我们有两个选择去实现它: 创建一个模型基类覆盖这个方法,所有的模型都来集成它即可; 创建一个 trait,在需要模型中引入它。...》 我们目标是使用表名来做为关系类别名,那么在模型中如何获取表名呢,直接使用模型 getTable 即可,那么整个 trait 实现如下: app/Traits/UseTableNameAsMorphClass.php...总结 以上所述是小编给大家介绍Laravel设置多态关系模型别名方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家。在此也非常感谢大家对ZaLou.Cn网站支持!

1.9K21

laravel ORM关联关系 withwhereHas用法

with 渴求式预加载 可以有效避免 N+1 问题,用法如下: $books = App\Book::with('author')- get(); 如果有多个关联关系可以用“,”隔开,还可以使用闭包来对关联关系进行限制...),没有筛选功能 with 更像 sql 中 join,就是你存不存都有执行,存在结果不为空,存在关联结果,不存在结果为空,关联结果为空 whereHas 查询存在关联关系,还有对应 whereDoesntHave...,适合查找 存在不存在 感觉 with 更多用在查看详情时候,你想知道你查看对象具体信息,关联到内容是怎样, 而 whereHas 更多用在筛选,你要把符合条件关联关系对象给他找出来。...就像用户发文章, user 存在关联关系 post,如果是 user- with(‘post’),你会得到所有用户用户发布文章信息,没发文章用户就没有文章信息,如果是 user- whereHas...这就是我对 with whereHas 一些理解了 以上这篇laravel ORM关联关系 withwhereHas用法就是小编分享给大家全部内容了,希望能给大家一个参考。

3.8K31

深入理解 Laravel Eloquent(三)——模型关系(关联)

所谓 “对象”,就是本文所说模型(Model)”;对象关系映射,即为模型关系。...一对一关系 顾名思义,这描述两个模型之间一对一关系。这种关系是不需要中间表。...假如我们有两个模型:User Account,分别对应注册用户消费者,他们是一对一关系,那么如果我们要使用 Eloquent 提供一对一关系方法,表结构应该是这样: user: id ......我们定义两个模型:Article Tag,分别表示文章和标签,他们是多对多关系。表结构应该是这样: article: id ... ... tag: id ... ......其他关系 Eloquent 还提供 “远层一对多关联”、“多态关联” “多态多对多关联” 这另外三种用法,经过上面的学习,我们已经掌握了 Eloquent 模型关系基本概念使用方法,剩下几种不常用方法就留到我们用到时候再自己探索吧

2.6K30

Laravel 多态关系表单验证

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

2.1K40

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

作为 Laravel 重度使用者肯定都对多态关系不陌生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型关系就是多态多对多(Many To Many (Polymorphic...))[1] 如果我们给 ID 为 1 文章打上两个标签,数据库标签关系存储结果就是这样子: > select * from taggables; +--------+-------------+...实现目标 我们有两个选择去实现它: 1.创建一个模型基类覆盖这个方法,所有的模型都来集成它即可;2.创建一个 trait,在需要模型中引入它。...》[2] 我们目标是使用表名来做为关系类别名,那么在模型中如何获取表名呢,直接使用模型 getTable 即可,那么整个 trait 实现如下: app/Traits/UseTableNameAsMorphClass.php...UseTableNameAsMorphClass { public function getMorphClass() { return $this->getTable(); } } 然后在我们需要用到关系类型模型中引入它即可

2.7K10

Laravel 模型事件应用

Laravel模型事件中处理起来很方便:https://laravel-china.org/docs/laravel/5.5/eloquent#events Laravel 模型事件有两种方式,...) LogBaseServer 新建一个观察器继承基类LogBaseServer(User模型,方法名字要对应文档中事件) LogBaseServer 到新建服务提供者...ObserverLogServiceProvider中运行 ObserverLogServiceProvider 为需要模型注册事件(我这挺多,之后大概长这样) 模型注册事件...然后我们触发一些事件(增删改,表数据就有了) 事件 多对多关联插入不会出触发模型(比如attach方法) 这时候就需要自己新建事件类来模拟(这里拿分配权限给角色粗略说一下) 在EventServiceProvider...中listen属性绑定好事件 EventServiceProvider 事件PermissionRoleEvent中注入两个参数,一个是角色,另一个是attach或者detach返回数组

16710

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

引言 上一章我们介绍了比较简单laravel模型关联关系一对一,介绍了关联操作方法。...belongsTo 关系 正好像对于一个词语,找到对应反义词,或者说有一个图片,找到其镜像图片这样。 有作用力,就有反作用力。一对一关系模型中,A有一个B,则反过来,B属于一个A。...我们使用State模型状态有多个Event事件这个场景,演示一下一对多关系声明,以及应用。...41; $event->save(); 注意,hasMany关联关系,返回是多个模型集合,可以后续链式调用集合所有方法。...写在最后 本文不失简单地介绍了belongsTohasMany两个关联关系,这在代码中仅次于hasOne关系, 使用频次比较高。而效率也就是根据外键多查询一次SQL消耗而已。

2.1K31

模型中AICBIC以及loglikelihood关系

「在进行建模时,经常要对模型进行评价:」 这个模型好不好? 这几个模型哪个好? 这两个模型是否达到显著性差异?...当两个模型之间存在较大差异时,差异主要体现在似然函数项,当似然函数差异不显著时,上式第一项,即模型复杂度则起作用,从而参数个数少模型是较好选择。...实例演示 「ASReml-R 文档中计算方法:」 这里: Ri为似然函数loglikelihood ti为参数个数 v为残差自由度 用两个模型模型1:动物模型,固定因子是SEXBYEAR,...「ASReml中LRT描述:」 「LRT检验前提」 两个模型固定因子一致 两个模型随机因子属于nested关系(包含关系,分级巢式模型) LRT应用一个前提条件是这些待比较模型应该是分级巢式模型...为了检验两个模型似然值差异是否显著,我们必须要考虑自由度。LRT 检验中,自由度等于在复杂模型中增加模型参数数目。这样根据卡方分布临界值表,我们就可以判断模型差异是否显著。

4.1K20

关系模型相关术语

基本术语 关系:整个二维表 关系名:表格名称 元组:行数据(记录) 属性:列数据(字段/分量) 属性名:列名称(字段名) 主键:唯一确定元组属性组(关键字) 域:属性取值范围 关系模式:关系描述...连接依赖:为提高规范化程度,都是通过把低一级关系模式分解为若干个高一级关系模式来实现,在此过程中,应该保证分解后产生关系模式与原来模式等价。...常用等价标准有两种:要求分解具有无损连接性要求分解保持函数依赖。 无损连接性判别:将关系模式R分解为关系模式R1,R2。...二、关系模式规范化 满足第一范式条件关系模式(1NF):关系模式 R每一个属性都是原子域,元组每一个分量都是不可分割数据项。...(限制关系模式属性之间不允许有非平凡且非函数依赖多值依赖) 满足第五范式条件关系模式(5NF):关系模式 R∈4NF,消除属于4NF关系模式中存在连接依赖。

93610

Gorm-模型关系定义标签 (一)

在Gorm中,除了定义模型字段标签外,还可以通过定义模型关系来描述不同表之间关联关系,以实现更加复杂数据操作。...定义模型关系在Gorm中,可以使用下列标签来定义模型关系:BelongsTo: 定义一对一或一对多关系“从属”模型。HasOne: 定义一对一关系“拥有”模型。...HasMany: 定义一对多关系“拥有”模型。ManyToMany: 定义多对多关系关联表。接下来,我们将介绍每个标签具体用法。...最后,我们通过将User模型Team字段与Team模型ID字段相关联,将两个模型关联起来。HasOneHasOne标签用于定义一对一关系“拥有”模型。...接着,我们定义了一个Profile模型,并将其与User模型相关联。最后,我们通过将Profile模型User字段与User模型ID字段相关联,将两个模型关联起来。

57430

Laravel框架视图模型操作方法分析

本文实例讲述了Laravel框架视图模型操作方法。分享给大家供大家参考,具体如下: 视图 简介:视图包含了应用程序渲染HTML数据,并将应用程序显示逻辑与控制逻辑有效分离开。...在Laravel中,视图被保存在resources/views目录中。...if(view()- exits('xxxx.xxx')); 视图数据 向视图传递数据 采用此方法传递数据,可以使用键/值获得对应数据,如 模型 简介:即MVC模式中Model,目录名为app根目录...相关内容感兴趣读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总...》 希望本文所述对大家基于Laravel框架PHP程序设计有所帮助。

1.3K21
领券