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

Laravel Eloquent 模型关联关系(下)

在前面两篇教程,学院君陆续给大家介绍了 Eloquent 模型类支持七种关联关系,通过底层提供关联方法,我们可以快速实现模型关联,并且进行关联查询。...whereHas/orWhereHas 方法基于闭包函数定义查询条件,比如我们想要过滤发布文章标题中包含「Laravel学院」所有用户: $users = User::whereHas('posts...此外,你还可以通过数组传递多个关联关系一次统计多个字段,还可以通过闭包函数指定对应统计过滤条件: $post = Post::withCount(['tags', 'comments' => function...在渴求式加载,也可以通过闭包传入额外约束条件,只不过这个约束条件是对关联模型自身过滤,不影响目标模型查询: $post = Post::with(['comments' => function...Eloquent 提供了这种同步机制帮助我们更新子模型时触发父模型更新时间 updated_at 字段值更新,要让该机制生效,需要在子模型配置 $touches 属性: // 要触发更新父级关联关系

19.5K30

3分钟短文:Laravel 模型查询数据库几个关键方法

引言 本期继续我们laravel学习,主要说一说laravel使用eloquent orm 模型 读取数据库条目的几个常用方法。 ?...学习时间 让我们最简单例子开始,就是获取数据库表内所有的条目,返回一个集合。...我们为这个查询添加条件,一遍精简输出内容: $vipContacts = Contact::where('vip', true)->get(); 筛选出所有vip合约。...顺带再说一下聚合函数,使用关系型数据库很大因素就是其拉取关系型数据很高效, 因此也内置了很多聚合函数用于数据聚合操作。...写在最后 本文主要讲了数据库查询相关内容,包括获取全量数据,获取单条数据, 分块拉取数据,以及聚合函数等,这些常规操作集合上期讲查询约束项, 基本上可以涵盖编程大多数需求了。

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

laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

分享给大家供大家参考,具体如下: 1、连接数据库 laravel连接数据库配置文件位于config/database.php,在其中connection字段包含laravel所支持数据库配置信息...方法可以添加数据库查询条件where()接收三个参数:字段名、操作符、值,操作符如果是’=’可以省略,例如查询id =1003数据: $res=DB::table('student')- where...Laravel内置Eloquent ORM提供了一种便捷方式帮助你组织数据库数据,每张数据表都对应一个该表进行交互模型(Model),通过Model类,你可以对数据表进行查询、插入、更新、删除等操作...在使用create批量添加时,需要在模板通过fillable指定可以赋值字段,也可以guard指定不允许赋值字段。...()、first()来获取数据 通过上面的增删改查可以看出Eloquent可以使用查询构建器所有方法,除了增删改查外,还有where、聚合函数等。

13.3K51

3分钟短文:Laravel 软删除说到模型作用域概念

我们软删除使用,再顺便说一说模型作用域概念。 代码时间 常规删除操作分两步进行,一步是把数据数据库查询出来,使用laravel模型方法, 则返回是一个模型对象。...所以引入了软删除概念,就是在表内添加一个字段,用于标记,这一行条目是否算是删除状态。在laravel, 这个软删除字段默认是 deleted_at。你也可以在模型手动指定。...模型相关代码如下: use Illuminate\Database\Eloquent\Model;use Illuminate\Database\Eloquent\SoftDeletes;class...('active', true); }); }} 那么所有的模型查询,都会默认加上声明where约束。...写在最后 本文laravel模型写操作删除动作,讲到了软删除概念。进而引申出来本地作用域和全局作用域使用。软删除几乎贯穿了我们应用始终,需要大家勤学苦练。

1.3K30

Laravel5.7 Eloquent ORM快速入门详解

简介 Laravel 内置 Eloquent ORM 提供了一个美观、简单数据库打交道 ActiveRecord 实现,每张数据表都对应一个该表进行交互模型(Model),通过模型类,你可以对数据表进行查询...该属性决定日期被如何存储到数据库,以及模型被序列化为数组或 JSON 时日期格式: <?...Eloquent all 方法返回模型所有结果,由于每一个 Eloquent 模型都是一个查询构建器,你还可以添加约束条件到查询,然后使用 get 方法获取对应结果: $flights = App...Laravel 自带软删除功能就使用了全局作用域来数据库拉出所有没有被删除模型。编写自定义全局作用域可以提供一种方便、简单方式来确保给定模型每个查询都有特定条件约束。...需要的话可以在 apply 方法添加 where 条件到查询: <?

15K41

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

四、查询构建器Laravel框架Eloquent ORM提供了方便查询构建器,用于构建复杂查询语句。下面是一些常用查询构建器方法。...where方法where方法用于添加条件查询,例如:$users = User::where('age', '>', 18)->get();上述代码,查询了年龄大于18岁所有用户。...orderBy方法orderBy方法用于添加排序条件,例如:$users = User::orderBy('created_at', 'desc')->get();上述代码,查询了按照创建时间倒序排列所有用户...总结通过上述文档和示例,我们可以看出Laravel框架Eloquent ORM提供了便捷对象关系映射功能,可以大大简化开发者数据库操作。...关联关系定义需要在对应模型定义,例如一对一关联需要在hasOne和belongsTo方法定义,一对多关联需要在hasMany和belongsTo方法定义,多对多关联需要在belongsToMany

1.5K41

通过 Laravel Eloquent 模型实现简单增删改查操作

,简单来说,它会构建类数据表之间映射关系,从而建立起一个可在编程语言里使用「虚拟对象数据库」。...「ActiveRecord」是 ORM 一种实现模式,Eloquent 则是 Laravel「ActiveRecord」。...属性为模型类指定使用哪个连接: protected $connection = 'connection_name'; 查询数据 日常开发,大部分操作都是数据库查询数据,Eloquent 模型了为我们提供了很多方法帮助我们数据库获取数据...此外,Eloquent 还为我们提供了一些快捷插入方法,比如 firstOrCreate 和 firstOrNew,这两个方法都会先尝试通过指定查询条件在数据库查找对应记录,如果没有找到的话,会创建对应模型实例...->delete(); 结语 在这篇教程,我们简单给大家介绍了 Eloquent 是什么,以及「约定优于配置」理念在 Eloquent 应用,最后还给大家演示了如何通过 Eloquent 实现数据库增删改查

7.9K20

orm 系列 之 Eloquent演化历程2

本文是orm系列第三篇,也是Eloquent演化第二篇,Eloquent系列会尝试着讲清楚Eloquent如何一步一步演化到目前功能强大版本,但是毕竟个人能力有限,不可能分析非常完善,总会有不懂地方...本文最后讲下Eloquent中新增对象之间关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 表结构 多态关联允许一个模型在单个关联下属于多个不同模型...模型结构 接下来,让我们看看构建这种关联关系需要在模型定义什么: <?...Manager,记得网上搜索过关键字Using Eloquent outside Laravel,我们可以看到一篇Vivek Kumar Bansal写文章,文章2方面介绍了怎么使用Eloquent...参考 [ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系

2.4K30

Laravel代码简洁之道和性能优化

思考:如何提高Model层查询DB效率?如何精简代码?...经过一番调研之后发现了一个堪称神器扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...如果互相喜欢,则添加双向联系人关系,插入之前校验是否存在,存在则更新type等字段,不存在则插入双向数据 我们通过这个场景能非常好体会laravel-upsert强大,不仅减少了代码量,也减少了sql...upsert()还将添加updated_at到更新。...当然了还是有一些注意点和坑,下面分享一下 注意问题 要根据需求添加唯一索引 根据官方文档说明,我们model必须添加这行代码,才能以Eloquent方式用 use \Staudenmeir\

5.7K20

Laravel源码分析之模型关联

上篇文章我们主要讲了Eloquent Model关于基础CRUD方法实现,Eloquent Model除了基础CRUD外还有一个很重要部分叫模型关联,它通过面向对象方式优雅地把数据表之间关联关系抽象到了...说了这么多下面我们就通过实际示例出发深入到底层看看模型关联是如何解决数据关联匹配和加载关联数据。 在开发我们经常遇到关联大致有三种:一对一,一对多和多对多,其中一对一是一种特殊一对多关联。...\Relations\BelongsToMany类实例,定义一对多关联时一样,实例化BelongsToMany时定义里关联相关配置:中间表名、关联模型、父模型在中间表外键名、关联模型在中间表外键名...,接下来通过 getEager方法获取所有的关联模型组成集合,再通过关联类里定义match方法把外键值等于父模型主键值关联模型组织成集合设置到父模型 $relations属性接下来用到了这些预加载关联模型时都是...模型关联常用一些功能底层实现到这里梳理完了,Laravel把我们平常用join, where in 和子查询都隐藏在了底层实现并且帮我们把相互关联数据做好了匹配。

9.5K10

3分钟短文 | Laravel复杂SQL超多WHERE子句,本地作用域你没用过

Laravel提供 eloquent orm 使用面向对象方式封装了PDO数据库操作,使用起来非常方便,对于复杂SQL操作也游刃有余。...今天说一说,复杂超多WHERE子句,怎么写起来较为优雅。 学习时间 比如对于业务逻辑,User模型在筛选查询时候有非常多限制条件,类似下面这样: ?...就拿这个 model 查询说起,你可以 "查询作用域”这么个时髦功能,有效分散和重用查询条件。 拿“全局作用域”来说,它可以给模型查询都添加上约束。...Laravel 软删除功能就是利用此特性数据库获取 “未删除”模型。 你可以编写你自己全局作用域,很简单、方便为每个模型查询都加上约束条件。看官方给出示例: ?...就是在对应 Eloquent 模型方法前添加 scope 前缀,在模型构造如下作用域方法: ?

2.7K10

Laravel学习记录--Model

Laravel 自带 软删除功能 就利用全局作用域数据库中提取「未删除」模型。编写自定义全局作用域可以提供一个方便、简单方法来确保给定模型每个查询都受到一定约束。...Eloquent还支持动态作用域,动态作用域指在查询过程动态设置预置过滤器查询条件,动态作用域本地作用域类似,都是以scope作为前缀,调用方法也相同,不同是动态作用域可以通过额外参数指定查询条件...uid(uid=1)musers表主键uid相匹配记录 dd($res); } 一对一反向关联 在上面我们muser模型访问到phone模型,现在从phone模型访问muser模型...Laravel中允许你自定义中间表模型,需要注意是中间表模型普通模型不一样 普通模型继承自Illuminate\Database\Eloquent\Model,而中间表模型继承自Illuminate...在调用save方法向Phone模型插入值 这里Eloquent自动在phones表添加了uid字段,并插入正确值 使用saveMany添加多个值 $user = \App\Muser::find

13.4K20

laravel框架模型和数据库基础操作实例详解

本文实例讲述了laravel框架模型和数据库基础操作。...; 3.Eloquent ORM 1.简介、模型建立及查询数据 简介:laravel所自带Eloquent ORM 是一个ActiveRecord实现,用于数据库操作。...每个数据表都有一个之对应模型,用于数据表交互。 建立模型,在app目录下建立一个Student模型,即Student.php,不需要带任何后缀。 <?...新增数据、自定义时间戳、批量赋值 (1)使用save方法新增 laravel会默认维护created_at,updated_at 两个字段,这两个字段都是存储时间戳,整型11位,因此使用时需要在数据库添加这两个字段...修改数据 使用save方法更新模型 使用update方法更新数据(和create相对应Eloquent模型类还支持使用update方法更新数据,同样要用到批量赋值) //通过模型更新数据 $student

2.8K20

Laravel系列4.3】模型Eloquent ORM使用(一)

最后在查询,我们也看到了类似于 查询构造器 链式调用形式,通过模型静态 where() 方法返回实例对象,一步步地构造整个查询。...这个 query where 条件是什么意思?就是我们上面这条 SQL 语句查询条件。它就是去查询 db_sex 表里面的数据,然后把获得结果对象返回回来。至于这个 ?...等等,不对呀,我们在模型里面定义是一个 gender() 方法,怎么在外面使用是一个属性?别急,我们再来看看源码,看看框架如何把调用属性变成调用一个方法。...然后来到最后 tap() ,tap() 是一个 Laravel 框架定义全局函数,和 env() 函数在一起,它作用是将第一个参数当作第二个参数参数传递给第二参数,并执行第二个参数后,将第一个参数再返回回来...下篇文章我们还将继续进行模型学习以及整个模型源码分析。 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

8.8K20

需要掌握 Laravel Eloquent 搜索技术

本文将带领大家学习 MySQL 和 Eloquent 在搜索模块设计相关技术。 基本 Eloquent Where 查询 作为首个要讲解搜索功能,我们先不涉及新知识点。...在 Laravel 可以使用 where 方法实现对给定字段和给定值进行比较查询,就是这样简单。 <?...它工作原理,类似 &&(查询) 运算符,当所有条件都为 true 时,返回结果集: <?...使用 Like 关键字 如何实现模糊查询呢?即实现 MySQL LIKE 查询。Eloquent 提供了比 where 语句更加灵活模糊查询功能。...依据单词发音进行模糊匹配 继续探讨最后一个主题,当用户输入查询表达式包含错误单词拼写时,该如何进行搜索呢?查询给定表达式有类似发音语句是个不错主意。

3.5K10

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

在本篇文章,我将跟大家一起学习 Eloquent 中最复杂也是最难理解部分——模型关系。...官方英文文档叫 Relationships,个人认为翻译成 “模型关系” 比现在 “关联” 更好理解一点哈哈。...由于前面的 `find(10)` 已经锁定了 id = 10,所以这段函数对应 SQL 为: `select * from account where user_id=10`。...---- 这段代码除了展示了一对一关系如何使用之外,还传达了三点信息,也是我对于大家使用 Eloquent 时候建议: 1....其他关系 Eloquent 还提供 “远层一对多关联”、“多态关联” 和 “多态多对多关联” 这另外三种用法,经过上面的学习,我们已经掌握了 Eloquent 模型关系基本概念和使用方法,剩下几种不常用方法就留到我们用到时候再自己探索吧

2.6K30

Laravel系列4.4】模型Eloquent ORM使用(二)

模型Eloquent ORM使用(二) 对于模型探索我们还将继续。上篇文章,只是简单地通过模型操作了一下数据库,并且学习了一下关联操作知识。...而我们在日常操作,其实最习惯是使用数组那种形式操作,除开我们后面会讲直接配置入手来修改 PDO FETCH 属性之外,我们还可以用上面这个 map() 函数配合模型对象 attributesToArray...\Models\MTest $mTest){ dump($mTest); dump($mTest->name); }); 通过在回调函数中注入模型对象,就可以实现路由模型绑定。...这是一个连续递进关系,之前在 查询构造器 文章,我们已经看到了它底层就是调用 原生查询 操作。那么这回,我们再来看一下 Model 方法,在底层是不是调用是 查询构造器 。...在所有模型都要继承 laravel/framework/src/Illuminate/Database/Eloquent/Model.php 类,我们很快就能发现一个 query() 静态方法。

2.8K20
领券