如何利用预加载优化Laravel Model查询详解
Laravel  /  管理员 发布于 8年前   317
前言 本文主要给大家介绍了关于利用预加载优化Laravel Model查询的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍: 介绍 对象关系映射(ORM)使数据库的工作变得非常简单。 在以面向对象的方式定义数据库关系时,可以轻松查询相关的模型数据,开发人员可能不会注意底层数据库调用。 下面将通过一些例子,进一步帮助您了解如何优化查询。 假设您从数据库收到了100个对象,并且每个记录都有1个关联模型(即belongsTo)。 默认使用ORM将产生101个查询; 如下所示: 我们在查询时没有告诉Post模型,我们还需要所有的作者,所以每次从单个Post模型实例获取作者的名字时,都会发生单独的查询。 array_maps时发生100次查询,加上先前一次查询,累计产生101次查询。 预加载 接下来,如果我们打算使用关联的模型数据,我们可以使用预加载将该101个查询总数减少到2个查询。 只需要告诉模型你需要什么来加载。如下: 如果你开启了sql日志,你将看到上述预加载将只会产生两条查询: 如果您有多个关联模型,则可以使用数组加载它们: 接下来我们重新定义如下关系 考虑下述情况:获取已发布文章所属作者的个人简介。 假设上述 通过优化预加载,我们可以避免嵌套关系中的额外查询。 你可以打开你的sql日志看到对应的三条查询。 懒惰加载 有时候您可能只需要根据条件收集相关联的模型。 在这种情况下,您可以懒惰地调用相关数据的其他查询: 查看您的sql日志,总共看到三个查询,但只有调用$posts->load()时才会显示。 结论 希望您更加了解有关加载型号的更多信息,并了解其在更深层次上的工作原理。 Laravel相关的文档已经很全面了,希望额外的实践练习可以帮助您更有信心优化关系查询。 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家的支持。 原文译自eloquent-eager-loading,简化其前面构造数据部分。//获取已发布的100条文章$posts = Post::limit(100)->get(); //一次查询$authors = array_map(function($post) { // 对作者模型生成查询 return $post->author->name;}, $posts);
//获取已发布的100条文章 - 并预加载文章对应作者$posts = Post::with('author')->limit(100)->get();//2次查询$authors = array_map(function($post) { // 对作者模型生成查询 return $post->author->name;//这里讲不在产生查询}, $posts);
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;});
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;});
您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号