位置: 编程技术 - 正文

如何利用预加载优化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万免税免的是哪些税
  • 审计库存现金盘点方法
  • 所有者投入的普通股会计分录
  • 会计核算体系的重要性
  • 筹建期的印花税计入现金流量表哪里
  • 子公司注销是利空吗
  • 零余额账户收到钱怎么办
  • 公司试驾车购置税怎么交
  • 股东补亏资金
  • 房地产开发成本费用明细表
  • 2020年餐饮业销售额
  • 德邦物流增值税发票怎么开
  • 工资薪金中的误餐补助,征收个人所得税
  • 低值易耗品属于资产类
  • 铝模租赁是怎么计算费用的,报价明细为你揭晓
  • 应税劳务、服务清单
  • apple ID怎么解绑设备
  • win7防火墙设置不了
  • 中秋节给员工买什么福利
  • 补缴以前月份的个人所得税
  • 为什么连接无线网超时
  • 蝴蝶兰的养殖方法和注意事项视频
  • PHP:imagepsfreefont()的用法_GD库图像处理函数
  • 发票章盖的不清楚可以在旁边再盖一个吗
  • 支付手续费方式委托代销商品确认收入
  • 取得企业债券利息为什么要交个人所得税
  • laravel 日志配置
  • 爱德华多·阿涅利
  • 收到银行承兑汇票的账务处理
  • 无形资产的摊销应计入什么科目
  • 无形资产摊销怎么算月摊销额
  • 出售自建不动产怎么交税
  • 帝国cms如何使用
  • 代收代付保险费分录
  • Ubuntu上安装jdk
  • mysql中游标的作用
  • 取得股息红利所得 个人所得税
  • 记账凭证如何进行记账
  • 外地施工企业异地施工
  • 建筑施工企业质量管理规范
  • 进项发票还未收到可以认证吗
  • 生产车间制造产品领用材料45000元,领用车间一半消耗
  • 公司开出发票但未收到款如何写分录?
  • 调表不调账都有什么情况
  • 收到公益性捐赠计入什么科目
  • 困难补助属于兜底政策吗
  • 新买固定资产怎么记账
  • 绿化植物税率
  • 其他应付款是否能大于收入
  • 个体工商户和公司的优缺点
  • 增值税纳税申报表在哪里打印
  • 为什么我们需要政府
  • mysql的ip怎么看
  • 注册表修改大全
  • mac可以上qq但是打不开网页
  • ubuntu升级到21.04
  • os x10.11el capitan beta4更新了什么?os x10.11el capitan beta4下载地址
  • 进程关不掉怎么解决
  • postgres.exe是什么进程 postgres进程查询
  • win7系统电脑蓝牙在哪里
  • dns轮询是什么意思
  • Linux系统开源VPN Openvpn进程异常退出解决方法
  • js设置窗口大小
  • shell 字符串trim
  • android studio项目无法运行
  • 审计局查什么内容
  • 国家电子税务局江苏省电子税务局
  • 河南省地方税务局公告2017年第4号
  • 契税的征收机关是哪里
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设