如何利用预加载优化Laravel Model查询详解

发布时间 - 2026-01-11 02:44:52    点击率:

前言

本文主要给大家介绍了关于利用预加载优化Laravel Model查询的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍:

介绍

对象关系映射(ORM)使数据库的工作变得非常简单。 在以面向对象的方式定义数据库关系时,可以轻松查询相关的模型数据,开发人员可能不会注意底层数据库调用。

下面将通过一些例子,进一步帮助您了解如何优化查询。

假设您从数据库收到了100个对象,并且每个记录都有1个关联模型(即belongsTo)。 默认使用ORM将产生101个查询; 如下所示:

//获取已发布的100条文章
$posts = Post::limit(100)->get(); //一次查询

$authors = array_map(function($post) {
 // 对作者模型生成查询
 return $post->author->name;
}, $posts);

我们在查询时没有告诉Post模型,我们还需要所有的作者,所以每次从单个Post模型实例获取作者的名字时,都会发生单独的查询。

array_maps时发生100次查询,加上先前一次查询,累计产生101次查询。

预加载

接下来,如果我们打算使用关联的模型数据,我们可以使用预加载将该101个查询总数减少到2个查询。 只需要告诉模型你需要什么来加载。如下:

//获取已发布的100条文章 - 并预加载文章对应作者
$posts = Post::with('author')->limit(100)->get();//2次查询

$authors = array_map(function($post) {
 // 对作者模型生成查询
 return $post->author->name;//这里讲不在产生查询
}, $posts);

如果你开启了sql日志,你将看到上述预加载将只会产生两条查询:

select * from `posts`
select * from `authors` where `authors`.`id` in (?, ?, ?, ?, ?) [1,2,3,4,5]

如果您有多个关联模型,则可以使用数组加载它们:

$posts = App\Post::with(['author', 'comments'])->get();

接下来我们重新定义如下关系

Post -> belongsTo -> Author //每个文章只属于一个用户
Author -> hasMany -> Post //每个用户拥有多个文章
Author -> hasOne -> Profile //每个用户只有一个简介

考虑下述情况:获取已发布文章所属作者的个人简介。

//获取所有文章 - 并预加载文章对应作者
$posts = App\Post::with('author')->get();//两次查询

//根据每个 `作者` 获取其简介
$posts->map(function ($post) {
 //虽然我们直接通过$author = $post->author不会产生查询,
 //但当调用$author->profile时,每次都会产生一个新查询
 return $post->author->profile;
});

假设上述App\Post::with('author')->get()有100条记录,将会产生多少条查询呢?

通过优化预加载,我们可以避免嵌套关系中的额外查询。

//获取所有文章 - 并预加载文章对应作者及每个作者对应de profile
$posts = App\Post::with('author.profile')->get();//三次查询

$posts->map(function ($post) {
 //不在产生新查询
 return $post->author->profile;
});

你可以打开你的sql日志看到对应的三条查询。

select * from `posts` 
select * from `authors` where `authors`.`id` in (?, ?, ?, ?, ?) [.....] 
select * from `profiles` where `profiles`.`author_id` in (?, ?, ?, ?, ?) [.....] 

懒惰加载

有时候您可能只需要根据条件收集相关联的模型。 在这种情况下,您可以懒惰地调用相关数据的其他查询:

$posts = App\Post::all();//一次查询

$posts->load('author.profile');//两次查询
$posts->map(function ($post) {
 //不在产生新查询
 return $post->author->profile;
});

查看您的sql日志,总共看到三个查询,但只有调用$posts->load()时才会显示。

结论

希望您更加了解有关加载型号的更多信息,并了解其在更深层次上的工作原理。 Laravel相关的文档已经很全面了,希望额外的实践练习可以帮助您更有信心优化关系查询。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

原文译自eloquent-eager-loading,简化其前面构造数据部分。


# laravel  # model  # 查询  # aravel  # 使用  # 浅谈laravel中的关联查询with的问题  # PHP中Laravel 关联查询返回错误id的解决方法  # laravel orm 关联条件查询代码  # laravel学习教程之关联模型  # Laravel关联模型中过滤结果为空的结果集(has和with区别)  # laravel withCount 统计关联数量的方法  # laravel ORM关联关系中的 with和whereHas用法  # Laravel 模型关联基础教程详解  # Laravel 关联模型-关联新增和关联更新的方法  # laravel 关联关系遍历数组的例子  # Laravel5中实现模糊匹配加多条件查询功能的方法  # laravel 框架结合关联查询 when()用法分析  # 加载  # 多个  # 两次  # 只需要  # 您的  # 如果你  # 都有  # 如果您  # 相关内容  # 你可以  # 将会  # 说了  # 不多  # 您可以  # 我们可以  # 只会  # 给大家  # 更有  # 只有一个  # 两条 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  详解jQuery停止动画——stop()方法的使用  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  JS中对数组元素进行增删改移的方法总结  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何在IIS中新建站点并配置端口与物理路径?  高性价比服务器租赁——企业级配置与24小时运维服务  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何在新浪SAE免费搭建个人博客?  Android自定义listview布局实现上拉加载下拉刷新功能  网站制作免费,什么网站能看正片电影?  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  Angular 表单中正确绑定输入值以确保提交与验证正常工作  想要更高端的建设网站,这些原则一定要坚持!  香港服务器租用费用高吗?如何避免常见误区?  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  PHP 500报错的快速解决方法  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel如何实现用户注册和登录?(Auth脚手架指南)  微信小程序 require机制详解及实例代码  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  如何快速启动建站代理加盟业务?  Laravel如何使用Collections进行数据处理?(实用方法示例)  如何在宝塔面板中创建新站点?  如何在云指建站中生成FTP站点?  用v-html解决Vue.js渲染中html标签不被解析的问题  香港服务器WordPress建站指南:SEO优化与高效部署策略  独立制作一个网站多少钱,建立网站需要花多少钱?  linux top下的 minerd 木马清除方法  Laravel如何自定义分页视图?(Pagination示例)  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  如何在云主机上快速搭建网站?  Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中  EditPlus中的正则表达式 实战(1)  如何在七牛云存储上搭建网站并设置自定义域名?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  大连网站制作公司哪家好一点,大连买房网站哪个好?  网站制作报价单模板图片,小松挖机官方网站报价?  如何挑选优质建站一级代理提升网站排名?  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  Laravel如何处理表单验证?(Requests代码示例)  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  如何快速生成凡客建站的专业级图册?