位置: 编程技术 - 正文

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

  • 税种有哪几种
  • 转让无形资产可以免税吗
  • 税务知识:同期资料应包括哪些内容?
  • 长期股权投资在哪个报表里
  • 专家劳务费可以税前扣除吗
  • 劳务派遣公司必须设立股东
  • 利息费用如何在记账软件输入
  • 企业缴纳印花税通过什么科目
  • 债务担保属于或有资产吗
  • 个体户2019年定额征收额度是多少
  • 减免所得税额是怎么算出来的2022
  • 交房前是否需要给房产局交房租维修费
  • 不动产增值税怎么算
  • 计税收入金额是什么意思
  • 小型微利企业所得税优惠政策2022
  • 旧房转让土地增值税计算
  • 风险纳税人怎么查原因
  • 合同作废合同
  • 物业收租金必须要发票吗
  • 法人给公司基本户打款
  • 出口退税款计入收入总额吗
  • 销售购物卡如何开票
  • 开通电子税务局需要什么资料
  • 计提的存货跌价准备
  • 腾讯手游助手卡顿严重
  • flash插件安装后还是不能播放
  • 专项扣除项目有上限吗
  • 进口代理流程
  • 城市生活垃圾处理方法
  • PHP:mb_ereg_search_regs()的用法_mbstring函数
  • pruttct.exe - pruttct是什么进程 有什么用
  • vue super
  • 3d reconstruction
  • openpose的输出
  • js中reduce用法
  • 毕业论文笔记怎么写
  • php连接数据库步骤
  • 财务核算科目核算流程图
  • 打车费属于差旅费吗
  • 债券发行费用包括
  • python中模块的概念
  • 银行对账单冲正的单据在财务软件哪里找
  • phpcms缩略图不要自动裁剪的设置方法
  • 房地产企业开发的已出租的房屋属于投资性房地产吗
  • 沙子产量表格
  • 哪些行业不用交税
  • 股东投钱一般怎么投
  • 退货开红字发票,已经交了消费税的怎么处理
  • 个体工商户核算方式选哪个比较好
  • 投资性房地产转固定资产账务处理
  • 纳税人及时提供信息
  • 企业转让专利需要交什么税
  • 合伙企业一般纳税人六税两费
  • 支付金额小于发票怎么办
  • 一次性伤残补助金是单位给的还是社保给的
  • 租赁房屋取得发票怎么开
  • 工程设计费收入在所得税申报表应填入
  • 税控盘清卡时间
  • 小规模附加税减半征收什么时候开始
  • 电子承兑被拒付(可拒付追索)
  • 财务会计是学什么课程
  • 建账基本要求
  • freebsd操作命令
  • 常用宏操作的参数设置方法
  • 手动防止Ping攻击方法(无需防火墙)
  • win8升级win10补丁
  • linux安装sshd服务
  • mac怎么卸载苹果系统
  • linux命令su-
  • Extjs4中的分页应用结合前后台
  • 浅析中国式现代化的理论价值与现实意义
  • nodejs爬取数据
  • python自动化部署k8s集群
  • jquery keydown
  • 国税局征管科
  • 江苏电子税务局社保缴费打印
  • 增值税电子普通发票需要盖章吗
  • 济南房产税如何计算公式
  • 个体工商户怎样交税
  • 湖北国家税务局发票查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设