位置: 编程技术 - 正文

如何利用预加载优化Laravel Model查询详解(预加载的目的是什么)

编辑:rootadmin

推荐整理分享如何利用预加载优化Laravel Model查询详解(预加载的目的是什么),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:预加载的目的是什么,简述预加载的作用,简述预加载的作用,什么是预加载,如何利用预加载文件,预加载时应注意什么问题,预加载的实现原理,如何利用预加载文件,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

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

介绍

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

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

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

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

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

预加载

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

如何利用预加载优化Laravel Model查询详解(预加载的目的是什么)

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

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

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

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

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

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

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

懒惰加载

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

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

结论

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

总结

标签: 预加载的目的是什么

本文链接地址:https://www.jiuchutong.com/biancheng/289980.html 转载请保留说明!

上一篇:Redis在Laravel项目中的应用实例详解(laravel 使用redis)

下一篇:基于Laravel5.4实现多字段登录功能方法示例

  • 一个工程中可以有多个主函数
  • 小规模纳税人代扣代缴个人所得税
  • 税务ukey使用教程视频
  • 收到商业汇票计入科目
  • 开普票要个人身份证号吗
  • 车险 专票
  • 发票管理中的四流一致是指什么一致
  • 税务1236600短信
  • 非正常损失会计利润调整
  • 同一张记账凭证可以出现多笔分录吗
  • 收到物业费普通发票做账
  • 捐赠现金计入什么科目
  • 企业所得税营业收入包括什么
  • 行政事业单位餐标
  • 金蝶固定资产管理
  • 公司收到股东的钱现金流量表怎么填
  • 广告位租赁合同要交印花税吗
  • 购买理财产品是不是非法集资
  • 小规模企业税务筹划
  • 小规模税控盘服务费怎么填增值税申报表
  • 违约金收入是否交增值税
  • 积极的财政政策有哪些
  • 非流动资产基金是什么意思
  • 如何控制网络速度
  • 电脑每次开机都要选择系统怎么办
  • 开增值税专用发票必须走公账吗
  • 支票存根属于什么凭证类型
  • 支付银行借款利息可以全额扣除吗
  • latex希腊字母斜体
  • 合并财务报表抵消原理
  • javascript手机编程
  • vue clonedeep
  • resize2fs命令 同步文件系统容量到内核
  • 调出command命令窗口
  • 工程检测业务
  • java守护线程和本地线程区别
  • 织梦自定义模型调用
  • Linux下实现MySQL数据备份和恢复的命令使用全攻略
  • mysql详细教程
  • dede织梦怎么转成zblog
  • 一次性就业补助金有时间限制吗
  • 利息补缴税款加收利息计算
  • 原材料盘亏属于自然损耗
  • 企业开户行信息是什么意思
  • mysql常见故障
  • 公司聘用临时工需要买社保吗
  • 临时用工费开票项目
  • 季度所得税申报表本年累计怎么填
  • 个人独资公司对外如何承担责任
  • 工人晚上加班的说说心情
  • 多计提的费用可以记收入吗会计分录
  • 利息收入缴纳税率怎么算
  • 政府部门拨款流程
  • 工资表的重要性
  • 建筑业收入叫什么
  • 待摊费用和预付费用的区别
  • 手机开个人发票怎么开
  • 农副产品免税发票可以抵扣吗?
  • 工程结算一般由什么等方式
  • 没有发票只有收据可以入账吗
  • 项目期间费用包括哪些费用
  • 物流行业会计核算特征有哪些
  • MySQL去除重复数据
  • sql 超时时间
  • 硬盘安装在哪里
  • win8cp
  • win7更改win10系统要怎么更改
  • msvcmm32.exe - msvcmm32是什么进程 有什么用
  • 一篇非常好的作文
  • 惠普笔记本的BIOS键
  • python函数详解
  • jQuery使用ajax方法解析返回的json数据功能示例
  • android怎么保存项目
  • Node.js中的事件循环是什么
  • Node.js中的事件循环是什么意思
  • c# 查找字符串
  • python的threading模块详解
  • jquery实战
  • jquery中用onclick绑定点击事件
  • 农产品进项税额核定扣除
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设