前言

本文主要给大家介绍了关于利用预加载优化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()用法分析
# 加载
# 多个
# 两次
# 只需要
# 您的
# 如果你
# 都有
# 如果您
# 相关内容
# 你可以
# 将会
# 说了
# 不多
# 您可以
# 我们可以
# 只会
# 给大家
# 更有
# 只有一个
# 两条
相关文章:
如何快速搭建二级域名独立网站?
建站主机与服务器功能差异如何区分?
建站之星如何配置系统实现高效建站?
如何在阿里云香港服务器快速搭建网站?
制作网站的公司有哪些,做一个公司网站要多少钱?
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
如何在局域网内绑定自建网站域名?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
如何基于云服务器快速搭建网站及云盘系统?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何通过多用户协作模板快速搭建高效企业网站?
高防服务器:AI智能防御DDoS攻击与数据安全保障
如何快速完成中国万网建站详细流程?
制作网站的基本流程,设计网站的软件是什么?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
如何在服务器上三步完成建站并提升流量?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
建站之星安装步骤有哪些常见问题?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
实例解析Array和String方法
网站插件制作软件免费下载,网页视频怎么下到本地插件?
如何通过PHP快速构建高效问答网站功能?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
建站主机类型有哪些?如何正确选型
GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?
建站主机选哪种环境更利于SEO优化?
建站之星代理商如何保障技术支持与售后服务?
如何在建站之星绑定自定义域名?
Python多线程使用规范_线程安全解析【教程】
黑客如何通过漏洞一步步攻陷网站服务器?
大同网页,大同瑞慈医院官网?
如何通过建站之星自助学习解决操作问题?
如何在Windows服务器上快速搭建网站?
建站之星微信建站一键生成小程序+多端营销系统
,怎么用自己头像做动态表情包?
如何用好域名打造高点击率的自主建站?
宝塔建站助手安装配置与建站模板使用全流程解析
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
定制建站是什么?如何实现个性化需求?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何通过商城免费建站系统源码自定义网站主题?
建站之星在线客服如何快速接入解答?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
北京营销型网站制作公司,可以用python做一个营销推广网站吗?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
*请认真填写需求信息,我们会在24小时内与您取得联系。