位置: 编程技术 - 正文

如何利用预加载优化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实现多字段登录功能方法示例

  • 税金及附加借贷科目
  • 个人所得税孩子小学升初中要修改吗?
  • 汇算清缴可以调成本吗
  • 居间费用超过3%剩余的怎样能拿到手
  • 减免税款会计分录
  • 个税app显示已离职是什么原因
  • 如何判断开专票还是普票
  • 个税申报截止日期2023年8月
  • 未取得发票如何进应付暂估科目
  • 营改增后增值税小规模纳税人按什么申报
  • 员工的家庭
  • 公车私用情形有哪些
  • 销售成本结转账务处理
  • 水电开发潜力
  • 其他应收款预算会计需要做账吗
  • 购买股票的分录怎么写
  • 外币报表折算差额怎么算
  • 多付几分钱怎么做账
  • 应收预收账款属于什么科目
  • 应收账款少给货款怎么做分录?
  • win10消费者版本和商业版本有什么区别
  • ghost读不出硬盘
  • 华为鸿蒙系统耗电量快吗
  • deepin启动延时
  • 银行承兑汇票有纸质的吗
  • 已抵扣的固定资产进项税转出如何处理
  • 施工费增值税专用发票税率
  • 企业支付个人劳务费需要发票吗
  • 鸿蒙系统网络差怎么解决
  • 预付账款主要是
  • 公司筹备期的费用
  • php基于反射机制实验报告
  • u盘安装win8系统步骤
  • dc.exe是什么程序
  • 如何选择一款适合自己家庭的凉席
  • 存货跌价准备减少
  • php代码大全及其含义
  • 最常用的成本核算方法表
  • 工程收到款项会计分录
  • centos7搭建http
  • In Java, how do I read/convert an InputStream to a String? Stack Overflow
  • 处置子公司利润表怎么处理
  • 财务核算科目核算流程图
  • 内账增值税计入什么科目
  • 出纳造工资表吗
  • 会计中报销费用是什么会计科目
  • jquery vue.js
  • javascript基础笔记
  • 对外捐赠固定资产会影响利润总额吗
  • 个人所得税是全国联网的吗
  • 撤销税务局
  • 免征水利建设基金条件
  • 银行理财产品是单利还是复利
  • 扣缴税款和情形有关系吗
  • 以货换货什么意思
  • 私车公用属于违反什么纪律
  • 专项应付款支出的账务处理
  • 固定资产报废如何进行账务处理
  • 活动经费要发到每个员工
  • 企业增资扩股如何办理
  • 结算本月应付职工工资,其中生产工人工资8000元
  • 利息收入和应收利息
  • 准备金支出是否含税
  • sql server 文件
  • fedora linux安装教程
  • 怎么检测u盘是否扩容
  • windows xp远程控制
  • linux更新内核的好处
  • regsvc32.exe - regsvc32是什么进程 有什么用
  • Linux的bg和fg命令简单介绍
  • 协程有什么用
  • jquery点击切换背景颜色
  • shell脚本实现批量移动文件
  • unity3d跨平台
  • unity3d documentation
  • 高新技术企业认定
  • 电子发票提取网站
  • 车辆购置税是财行税吗
  • 国税网站怎么登录进入
  • 预缴的税额可以用留底抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设