前言

本文主要给大家介绍了关于利用预加载优化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相关的文档已经很全面了,希望额外的实践练习可以帮助您更有信心优化关系查询。

总结

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

php8预加载,如何利用预加载优化Laravel Model查询详解相关推荐

  1. java io类库,Java利用io类库对各种文件的操作详解

    Java中文网 - Java利用io类库对各种文件的操作详解 java中提供了io类库,可以轻松的用java实现对文件的各种操作.下面就来说一下如何用java来实现这些操作. 新建目录 //Strin ...

  2. php可以打印一个页面,利用html实现分页打印功能的实例详解

    本篇介绍利用html实现分页打印功能的实例详解,有些不想打印出来的分页打印的都可以应用这类样式进行控制 在非打印时是无效的. 页面打印 /* 应用这个样式的在打印时隐藏 */ .noPrint { d ...

  3. 利用Animation控件制作帧动画过程详解

    利用Animation控件制作帧动画过程详解 前言 通过Animation控件来达到序列图的播放(素材和示例视频在文章末尾) 一.序列图 (此素材为已经分割好的序列图) 如若序列图在一张图片上,请参考 ...

  4. ajax异步同步加载PHP代码,jquery中的ajax同步和异步详解

    jquery ajax同步的意思是当JS代码加载到当前ajax的时候会把页面里所有的代码停止加载,页面出现了假死状态,当这个ajax执行完毕后才会继续运行其他的代码假死状态解除.而异步的意思是这个aj ...

  5. Asp.NetMVC利用LigerUI搭建一个简单的后台管理详解(函登录验证)

    上一篇 Asp.Net 中Grid详解两种方法使用LigerUI加载数据库数据填充数据分页 了解了LigerUI 中Grid的基本用法  现在结合上一篇的内容做一个简单的后台管理,当然也有前台的页面. ...

  6. foxmail邮件加载失败重试_java retry(重试) spring retry, guava retrying 详解

    系列说明 java retry 的一步步实现机制. java-retry 源码地址 情景导入 简单的需求 产品经理:实现一个按条件,查询用户信息的服务. 小明:好的.没问题. 代码 UserServi ...

  7. php滚动加载分页,jQuery scroll事件实现监控滚动条分页实例详解

    这篇文章主要介绍了jQuery scroll事件实现监控滚动条分页简单示例,使用ajax加载,同时介绍了(document).height()与$(window).height()的区别,需要的朋友可 ...

  8. 加载vue文件步骤_vue中.vue文件解析步骤详解

    这次给大家带来vue中.vue文件解析步骤详解,vue中.vue文件解析的注意事项有哪些,下面就是实战案例,一起来看一下. 我们平时写的 .vue 文件称为 SFC(Single File Compo ...

  9. 怎么给网站加js_网站站内SEO优化实操细节详解,权重上升嗖嗖的

    做SEO优化的都知道,网站SEO排名的好与坏,影响的因素非常多.而站内优化是重要的一个因素,如果按满分100分来计算,菜鸟菌觉得站内优化至少占20分左右.因此,站内的优化是很重要的,但也不能说做好站内 ...

最新文章

  1. android接收不能广播,【11-16求助】急急急,service中无法接收广播!
  2. JavaScript: 代码简洁之道
  3. win7 计算机库 桌面,【备忘】win7下再硬盘安装win7(桌面库和家庭组图标删除)...
  4. SSIS中的容器和数据流—调试工具数据视图
  5. sqoop操作之Oracle导入到HDFS
  6. 没得玩了!腾讯这款游戏宣布将于12月15日停服
  7. 反射(3)—动态、静态代理
  8. jquery计算两个日期天数差
  9. php如何打包成apk,windows下PHP批量生成打包android程序APK
  10. Little Gyro and Sets(第二届中国计量大学ACM程序设计竞赛个人赛)
  11. TCP粘包问题分析和解决
  12. 家居3d网上展示_三维模型可视化展示
  13. 承上启下的总结+从吴军的书《态度》总结出的20条为人方法生活状态
  14. Python爬虫报错 ImportError: cannot import name Morsel
  15. 链游Illuvium即将上线:自动战斗P2E NFT收藏游戏
  16. Hexo系列matery主题踩坑优化记录
  17. [转]马化腾:如何从“较好”到“最好”
  18. RGBA图像的四通道详细分析
  19. 开发人员360杀毒软件的配置
  20. 7-2 地下迷宫探索 (30分)

热门文章

  1. Kubernetes控制平面组件:Kubelet
  2. Rust入坑指南:核心概念
  3. OpenCV系列之如何使用背景分离方法 | 四十六
  4. vue3 router.push 传参路由跳转错误提示 Argument type {xxx} is not assignable to parameter type RouteLocationRaw
  5. ISO16000-9建筑产品和家具中挥发性有机物的测试
  6. 【ArcGIS|空间分析】数字地形分析
  7. gtx1060 能用catia软件吗_为何垃圾独显作设计比核显强?
  8. Win10打开SQL Server2014的SQL Server配置管理器
  9. python绘制多边形_在python matplotlib中绘制三维多边形
  10. 05 - 微信小程序实例开发 - 综合小娱乐