位置: 编程技术 - 正文

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

  • 转让金融商品需要缴纳增值税吗
  • 出售写字楼需要什么手续
  • 企业税号还未开户
  • 资产负债表里的应收账款怎么取数
  • 个税漏申报了一个月在哪里申报
  • 个体户每个月开10万会查吗
  • 公司买金蝶计入什么科目
  • 本地的住宿费怎么交
  • 个人取得哪项收入需要缴纳个人所得税
  • 非营利组织的项目管理流程包括
  • 应收债权属于非抵押吗
  • 原始凭证丢失如何处理会罚款吗
  • 应付账款的进项税分录
  • 应交税费附加税期末有余额吗
  • 纳税总额包括代扣代缴个人所得税吗
  • 金蝶软件开发服务费入什么科目?
  • 营改增之后的税率
  • 自产自销产品如何入库存
  • 装修公司一般纳税人纳税标准
  • 无票收入增值税申报表怎么填小规模纳税人
  • 物业管理体现在哪些地方
  • 国资委是什么
  • 2021年季度所得税申报表填报说明
  • 所得税税前扣除税金有哪些
  • 期末调汇的会计处理
  • mac怎么转到苹果系统
  • 开具给个人的发票哪里查询
  • iis搭建php环境
  • 直系亲属股权转让免征个人所得税
  • 发生坏账账务处理
  • 最薄的平板电脑是哪种
  • 网站国际化方案
  • 固定资产加速折旧方法
  • php截取文件后缀名方法
  • php获取文件后缀名的方法
  • 印花税的相关问题
  • spring ioc di aop
  • libev & libevent简介 IntelIOT 博客园
  • golang 调用动态库
  • 库存盘点差异会计分录
  • 金税盘怎么取消
  • 预提和计提
  • 普通发票不满8项怎么开明细
  • mysql 子查询
  • dedecms上传视频
  • 税款所属期止是怎么写
  • 企业转让无形资产的方式有
  • 排污收费制度在排污费征收方面存在的问题
  • 没有金税盘可以开专票吗
  • 管理费用冲减其他应付款分录
  • 残疾人报税怎么报
  • 以前年度损益调整属于哪类科目
  • 开具专票需要哪些材料
  • 租车运货产生的费用
  • 财务费用在贷方表示增加还是减少
  • 农业免税企业开票有限额吗
  • 金蝶k3如何反记账
  • 软件开发收费标准
  • 冲回以前年度工会费
  • mysql修改允许远程连接
  • sql连接两个表接查询sql语句
  • mysqlbinlog -vvv
  • win2003注册表空间不足
  • windows命令提示符命令大全
  • xp系统提升性能
  • netsurf.exe - netsurf是什么进程 有什么用
  • 给div设置滚动条
  • javascript 数组操作
  • dos强制删除文件命令
  • 分享两句话
  • javascript的
  • node.js中实现同步操作的3种实现方法
  • node.js介绍
  • [置顶]电影名字《收件人不详》
  • 安卓 centos
  • 面向对象的程序设计语言是
  • python中的格式化输出用法总结
  • 税务申报显示重名怎么办
  • 长春购房契税税率
  • 山东省工会经费收支管理办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设