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

Laravel Eloquent 模型关联关系(下)

在前面两篇教程中,学院君陆续给大家介绍了 Eloquent 模型类支持的七种关联关系,通过底层提供的关联方法,我们可以快速实现模型间的关联,并且进行关联查询。...whereHas/orWhereHas 方法基于闭包函数定义查询条件,比如我们想要过滤发布文章标题中包含「Laravel学院」的所有用户: $users = User::whereHas('posts...: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users = User::whereHas('posts', function...学院%'); })->whereHas('posts.comments', function ($query) { $query->where('content', 'like', 'Laravel...Eloquent 提供了这种同步机制帮助我们更新子模型时触发父模型的更新时间 updated_at 字段值更新,要让该机制生效,需要在子模型中配置 $touches 属性: // 要触发更新的父级关联关系

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

    Laravel学习记录--Model

    Laravel 自带的 软删除功能 就利用全局作用域从数据库中提取「未删除」的模型。编写自定义的全局作用域可以提供一个方便、简单的方法来确保给定模型的每个查询都受到一定的约束。...嵌套的渴求式加载 渴求式加载指定字段 带条件约束渴求式加载 懒惰式渴求式加载 当以属性方式访问Eloquent关联关系的时候,关联关系数据是[懒惰式加载]因为都是用到的时候才执行查询,这就意味着要多次对数据库进行查询才能返回需要的结果...使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]的好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我的另一个博客 - - - Laravel...渴求式加载多个关联关系 有时候你需要在单个操作中渴求式加载多个不同的关联关系,要实现这一功能,只需添加参数到with方法即可 ,以逗号分割 如,查询文章的作者即所在栏目 嵌套的渴求式加载 要使用嵌套的渴求式加载的关联关系...,现在通过课程id查询选修的学生 在Mclass模型中定义一个stus方法,这个方法还是调用belongsToMany();并返回值 如: //获取选修此课程的学生 public function

    13.6K20

    跟我一起学Laravel-EloquentORM进阶部分

    关联关系 One To One 假设User模型关联了Phone模型,要定义这样一个关联,需要在User模型中定义一个phone方法,该方法返回一个hasOne方法定义的关联 的是,默认情况下之后模型的键可以通过pivot对象进行访问,如果中间表包含了额外的属性,在指定关联关系的时候,需要使用withPivot方法明确的指定列名 return $this->belongsToMany...通常情况下我们可能会使用自定义的值标识关联的表名,因此,这就需要自定义这个值了,我们需要在项目的服务提供者对象的boot方法中注册关联关系,比如AppServiceProvider的boot方法中 use...关联关系查询 在Eloquent中,所有的关系都是使用函数定义的,可以在不执行关联查询的情况下获取关联的实例。...预加载多个关系 $books = App\Book::with('author', 'publisher')->get(); 嵌套的预加载 $books = App\Book::with('author.contacts

    4K50

    Laravel源码分析之模型关联

    上篇文章我们主要讲了Eloquent Model关于基础的CRUD方法的实现,Eloquent Model中除了基础的CRUD外还有一个很重要的部分叫模型关联,它通过面向对象的方式优雅地把数据表之间的关联关系抽象到了...按照Laravel设定好的模式来写关联模型每个人都能写出高效和优雅的代码 (这点我认为适用于所有的Laravel特性)。...类的实例,与定义一对多关联时一样,实例化BelongsToMany时定义里与关联相关的配置:中间表名、关联的模型、父模型在中间表中的外键名、关联模型在中间表中的外键名、父模型的主键、关联模型的主键、关联关系名称...,在获取关联模型时给关系应用约束的 addEagerConstraints方法是在具体的关联类中定义的,我们可以看下HasMany类的这个方法。...模型关联常用的一些功能的底层实现到这里梳理完了,Laravel把我们平常用的join, where in 和子查询都隐藏在了底层实现中并且帮我们把相互关联的数据做好了匹配。

    9.6K10

    Laravel中使用路由控制权限(不限于Laravel,只是一种思想)

    每一个页面认证当前需要的权限一次 在统一的地方(中间件)验证 先上一下简单的表结构(只保留重要的信息)数据库的模型 ER 图 数据库模型图 (ps:这个设计中,用户不会直接拥有权限,只能通过角色继承权限...php namespace App\Models; class Role extends Model { // 用户和角色的模型关联关系 public function users()...{ return $this->belongsToMany(User::class); } // 角色和权限的模型关联关系 public function permissions...php namespace App\Models; class Permission extends Model { // 角色和权限的模型关联关系 public function...,还是要在不同的方法进行验证,而且可扩展性不高,这时候我们只需要在权限表加一个字段,就可以解决问题 1. permissions (加多一个 route 字段, 如果不在 laravel 中使用,可以加一个

    22110

    Django Rest Framework中嵌套关系的JSON序列化

    在 Django Rest Framework (DRF) 中,处理嵌套关系的 JSON 序列化是一个常见需求。以下是如何实现嵌套关系序列化的详细说明,包括序列化器定义、模型关系以及常见用法。...return self.jobmst_name class Meta: managed = False db_table = 'jobmst'我们希望能够将这两个模型的数据序列化成一个嵌套的...访问URL http://localhost/TidalDEV/50244/,会返回Jobmst和Jobdtl模型数据的JSON序列化结果,其中Jobmst的jobmst_id为50244。...总结通过以上步骤,我们实现了在Django Rest Framework中对嵌套关系的JSON序列化。这为我们提供了更加灵活的方式来处理复杂的数据结构,并将其转换为JSON格式。...这样可以高效处理复杂的嵌套关系,提升 API 的可用性和性能!

    11010

    PHP-web框架Laravel-Eloquent ORM(二)

    三、模型关联Laravel框架中的Eloquent ORM提供了方便的模型关联功能,用于定义不同表之间的关联关系。下面是几个常用的模型关联类型。...定义了一个User模型和一个Phone模型,通过在User模型中定义phone方法和在Phone模型中定义user方法,实现了这两个模型之间的一对一关联关系。...定义了一个Post模型和一个Comment模型,通过在Post模型中定义comments方法和在Comment模型中定义post方法,实现了这两个模型之间的一对多关联关系。...多对多关联多对多关联表示两个模型之间存在多对多的关联关系。下面是一个示例:中,定义了一个User模型和一个Role模型,通过在User模型中定义roles方法和在Role模型中定义users方法,实现了这两个模型之间的多对多关联关系

    63341

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

    在本篇文章中,我将跟大家一起学习 Eloquent 中最复杂也是最难理解的部分——模型间关系。...官方英文文档中叫 Relationships,个人认为翻译成 “模型间关系” 比现在的 “关联” 更好理解一点哈哈。...... account_id account: id ... ... user_id 假设我们需要在 User 模型中查询对应的 Account 表的信息,那么代码应该是这样的。...重要技巧:关系预载入 你也许已经发现了,在一对一关系中,如果我们需要一次性查询出10个 User 并带上对应的 Account 的话,那么就需要给数据库打 1 + 10 条 SQL,这样性能是很差的。...我们可以使用一个重要的特性,关系预载入:http://laravel-china.org/docs/eloquent#eager-loading 直接上代码: $users = User::with('

    2.7K30

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

    前言 今天弄了一天的关于文章的功能,其中主要卡在文章与标签的多对多的关系纠结中。卡了半天,终于算是解决了,不是很完美,但可以。 新建迁移文件 多对多的关系中,需要三张表。...这是我是文章表【articles】、标签表【tags】以及关系表【article_tag】 其中关系的命名是[article_tag]而不是tag_article 因为laravel默认是以字母升序排列...中包含article_id一样的记录也删除 执行迁移 php artisan migrate 声明Eloquent的关系 Article ?...我们使用 $this->belongsToMany() 来表明Eloquent的关系,这里需要注意的是如果你的外键并不是 article_id 和 tag_id ,你需要在第三个参数进行设置,写成类似下面这样...后来经过查阅多方资料以及官方文档,才发现,想要标签表中的值唯一,而关系表中通过tag_id来标记不能这样写。

    1.8K00

    最为常用的Laravel操作(1)-Eloquent模型

    $books = App\Book::with('author', 'publisher')->get(); // 嵌套的渴求式加载 $books = App\Book::with('author.contacts...->account()->associate($account); $user->save(); // 移除关联 (belongsTo) // dissociate 方法会设置关联关系的外键为 null...]); // 从中间表中移除相应的记录: 指定用户移除某个角色 $user->roles()->detach($roleId); // 从中间表中移除相应的记录: 指定用户移除所有角色 $user->...例如, 你可能想要使用 Laravel 加密器对存储在数据库中的数据进行加密, 并且在 Eloquent 模型中访问时自动进行解密....你可以自定义哪些字段被自动调整修改, 甚至可以通过重写模型中的 $dates 属性完全禁止调整: class User extends Model { /** * 应该被调整为日期的属性

    35200

    谈谈我第一次如何为 Laravel 贡献源码

    事情的起源是因为在调试一段模型事件时出现的,当时随便往数据库里插入了一段字符串 ID,而不是标准的 uuid。然后发现我的模型事件中查找不到当前 ID 的模型。...当然,我们不可能总是能遇到问题,也有可能遇到了问题是自己的错误,这时候可以去Laravel的问题库看一下自己有什么能解决的问题 进展 先排除了自己本身代码中的错误,然后一步一步调试 控制器...事件 Log 打印了一下返回变量,发现belongsToMany::sync方法返回的 ID 并不正确。...但我在模型中已经设置了主键类型为字符串,这不应该是我想要的结果。...尽情的表达你的想法,社区有很多人会帮助你的 最后欢迎加入Laravel学习交流群,群号:584453488

    12310

    Laravel5.2之Seeder填充数据小技巧

    说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...mpociot/laravel-test-factory-helper --dev 然后在config/app.php文件中填上: /** *Develop Plugin...设计字段 按照上文提到的Category、Post、Comment和Tag之间的关系创建迁移Migration和模型Model,在项目根目录输入: php artisan make:model Category...,还需要一张存放两者关系的表: //多对多关系,中间表的命名laravel默认按照两张表字母排序来的,写成tag_post会找不到中间表 php artisan make:migration create_post_tag_table...分享下最近发现的一张好图和一篇极赞的文章: 文章链接:Laravel的中大型專案架構

    3.6K42

    PHP-web框架Laravel-Eloquent ORM(三)

    四、查询构建器Laravel框架中的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...join方法join方法用于关联查询,例如:$users = User::join('orders', 'users.id', '=', 'orders.user_id')->get();上述代码中,查询了用户和订单表中符合条件的所有记录...总结通过上述文档和示例,我们可以看出Laravel框架中的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...它支持多种关联关系,包括一对一、一对多和多对多等,并且提供了方便的查询构建器,用于构建复杂的查询语句。...关联关系的定义需要在对应的模型类中定义,例如一对一关联需要在hasOne和belongsTo方法中定义,一对多关联需要在hasMany和belongsTo方法中定义,多对多关联需要在belongsToMany

    1.5K41

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

    ,在关联关系的建立过程中,Eloquent 也遵循了「约定大于配置」的原则。...你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认的约定。...建立相对的关联关系 与一对一一样,我们可以在文章模型中建立与用户模型之间的相对关联关系,而且这种使用场景很普遍,比如在文章详细页或列表页显示文章作者信息。...接下来,我们在 Post 模型类中定义其与 Tags 模型类的关联关系,通过 Eloquent 提供的 belongsToMany 方法来实现: public function tags() {...建立相对的关联关系 与之前的关联关系一样,多对多关联也支持建立相对的关联关系,而且由于多对多的双方是平等的,不存在谁归属谁的问题,所以建立相对关联的方法都是一样的,我们可以在 Tag 模型中通过 belongsToMany

    10K40

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

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

    2.7K10

    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 属性也相应返回数据库内的字段值...写在最后 本文不失简单地介绍了belongsTo和hasMany两个关联关系,这在代码中仅次于hasOne关系, 使用的频次比较高的。而效率也就是根据外键多查询一次SQL的消耗而已。

    2.1K31

    orm 系列 之 Eloquent演化历程1

    Eloquent Eloquent是laravel中的orm,采取的是active record的设计模式,里面的对象不仅包括领域逻辑,还包括了数据库操作,但是大家平时使用的时候可能没有探究eloquent...此时关系处理上主要的逻辑是调用Model的HasOne等表关系的方法,返回Relation的子类,然后通过Relation来处理进而返回数据,这么说可能有点绕,我们下面具体介绍下每个关系的实现,大家可能就理解了...('App\User'); } } 这个关系我们稍微具体讲下,我们在使用上可能会是下面这样子的 return $this->belongsToMany('App\Role', 'user_roles...', 'user_id', 'role_id'); 在构造函数中,会调用addConstraints方法,如下 // class belongsToMany public function addConstraints...role,join表user_role 在get的时候,其逻辑和HasOne等关系也所有不同,代码如下: // class belongsToMany public function get($columns

    1.1K30

    Laravel 软删除存在的问题

    ,如果类常量DELETED_AT为null,则不执行相应的软删除操作 4、join操作,只会在对当前模型添加软删除查询条件 5、在belonsToMany关联关系中,如果关联表,中间表,被关联表都有软删除字段...,查询关联关系,不会对中间表应用软删除条件 belonsToMany中的中间表是传入的表名参数,天然没办法获取中间表是否需要应用软删除。...被关联表是一个类对象,如果应用了软删除,则会自动附加上软删除条件 6、在hasManyThrough关联关系中,如果关联表,中间表,被关联表都有软删除字段,查询关联关系,会对中间表应用删除条件。...但是,如果要查询包含已删除的关联关系,中间表的删除标记条件不会去除。 hasManyThrough中,中间表是通过中间对象传入,可以获取到中间表是否应用软删除。...从上面可以看出,Laravel的软删除,在关联关系中会造成一些查询上条件的歧义,非常容易产生bug.而且,belongsToMany中间表的问题是无解的。

    2.3K20
    领券