位置: 编程技术 - 正文
推荐整理分享如何利用预加载优化Laravel Model查询详解(预加载的目的是什么),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:预加载的目的是什么,简述预加载的作用,简述预加载的作用,什么是预加载,如何利用预加载文件,预加载时应注意什么问题,预加载的实现原理,如何利用预加载文件,内容如对您有帮助,希望把文章链接给更多的朋友!
前言
本文主要给大家介绍了关于利用预加载优化Laravel Model查询的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍:
介绍
对象关系映射(ORM)使数据库的工作变得非常简单。 在以面向对象的方式定义数据库关系时,可以轻松查询相关的模型数据,开发人员可能不会注意底层数据库调用。
下面将通过一些例子,进一步帮助您了解如何优化查询。
假设您从数据库收到了个对象,并且每个记录都有1个关联模型(即belongsTo)。 默认使用ORM将产生个查询; 如下所示:
我们在查询时没有告诉Post模型,我们还需要所有的作者,所以每次从单个Post模型实例获取作者的名字时,都会发生单独的查询。
array_maps时发生次查询,加上先前一次查询,累计产生次查询。
预加载
接下来,如果我们打算使用关联的模型数据,我们可以使用预加载将该个查询总数减少到2个查询。 只需要告诉模型你需要什么来加载。如下:
如果你开启了sql日志,你将看到上述预加载将只会产生两条查询:
如果您有多个关联模型,则可以使用数组加载它们:
接下来我们重新定义如下关系
考虑下述情况:获取已发布文章所属作者的个人简介。
假设上述AppPost::with('author')->get()有条记录,将会产生多少条查询呢?
通过优化预加载,我们可以避免嵌套关系中的额外查询。
你可以打开你的sql日志看到对应的三条查询。
懒惰加载
有时候您可能只需要根据条件收集相关联的模型。 在这种情况下,您可以懒惰地调用相关数据的其他查询:
查看您的sql日志,总共看到三个查询,但只有调用$posts->load()时才会显示。
结论
希望您更加了解有关加载型号的更多信息,并了解其在更深层次上的工作原理。 Laravel相关的文档已经很全面了,希望额外的实践练习可以帮助您更有信心优化关系查询。
总结
标签: 预加载的目的是什么
本文链接地址:https://www.jiuchutong.com/biancheng/289980.html 转载请保留说明!友情链接: 武汉网站建设