位置: 编程技术 - 正文

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

  • 贷款其他消费是指什么
  • 国有企业投资方式
  • 个体工商户开普票限额最新规定
  • 母公司与子公司的区别
  • 社保利息计入什么科目
  • 事业单位无形资产管理制度
  • 作家以及作品
  • 出纳都需要做什么表格
  • 机票报销需要什么单据
  • 股权转让金是什么意思
  • 什么是差额增收
  • 募集资金怎么算
  • 固定资产一次性扣除政策2023
  • 小微企业增值税申报表怎么填
  • 劳务发票属地原则
  • 软件企业涉税风险分析
  • 金税盘全额抵扣分录
  • 融资租赁购入固定资产开票吗
  • 对外投资的风险及对策
  • 金银制成的金银币及摆件是否征收消费税?
  • 附有销售退回条款的递延所得税问题
  • 股权筹资的概念
  • 清算资本公积中的股本溢价应该怎么处理
  • 销售残次品怎么处罚
  • 业务招待费是什么科目
  • 运费用会计分录
  • 请等待当前程序完成或更改怎么弄
  • php进程数量怎么决定
  • php vld
  • 注册造价师挂靠费怎么缴纳个税
  • 圆顶亭效果图
  • php删除语句
  • 海峡群岛属于哪个洲
  • php常用语句
  • yii2-admin
  • f12过滤请求
  • yolov5s
  • vmware17虚拟机安装教程
  • 高德地图的2种导航方式
  • 个体工商户开普通发票需要交税吗
  • 暂估入库成本处理
  • 酒店周转材料怎么摊销
  • 包装物押金销项税额的计算
  • 生产成本怎么结账
  • 公司优秀党员奖章
  • 个人所得税如何扣税
  • 同一控制和非同一控制的区别图解
  • 劳务报酬所得是否含增值税
  • 物业电费加价如何处理
  • 留抵会计分录
  • 房地产业营改增税收政策与企业应对策略课后测试
  • 进项增值税发票抵扣期限
  • 固定资产原值会减少吗
  • 客户要赔偿怎么回复
  • 加油费不征税发票可以报销吗
  • 个人为什么不能购买永续债
  • 租来的办公室装修费摊销几年
  • 计算机二级考试一年考几次
  • SQL中distinct 和 row_number() over() 的区别及用法
  • ghost读取不到硬盘
  • 苹果mac录制屏幕
  • linux修改yum
  • linux的压缩包
  • win7任务栏快捷启动如何设置
  • 在windows中用于显示正在运行的程序名称的栏称为
  • xp系统如何更改开机启动项
  • 域名解析a记录怎么填
  • android自定义搜索框
  • 使用权资产
  • jquery移动节点的方法
  • android本地保存数据
  • shell备份文件脚本
  • firefox margin-top失效的原因与解决办法
  • 炉石 xhope
  • unity3d需要什么语言
  • node的express
  • JavaScript split()使用方法与示例
  • android studio ndk开发教程
  • js立即执行函数作用
  • 如何理解计算消费税时的(1
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设