位置: 编程技术 - 正文

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

  • 购买需要安装的设备会计分录
  • 哪些企业需要缴纳企业所得税?
  • 消费税到底是什么
  • 防伪税控技术维护费怎么申报
  • 暂估入库收到发票后怎么做分录
  • 分期收款方式确认销售收入
  • 主税零申报附加税怎样申报
  • 未确认融资收益怎么算
  • 期初数调整的分录怎么做
  • 冲销以前年度营业外支出
  • 企业基本医疗保险和综合医疗保险
  • 计提存货减值准备怎么算
  • 差旅费包括哪些明细
  • 购入工程物资计入
  • 法人收到票据用什么抵扣
  • 车间员工的质量管理制度
  • 购置办公大楼
  • 预收账款缴税的计算公式
  • 电子发票开错了怎么解决?
  • 关于国际货运代理协会联合会的描述不正确的是
  • 应交增值税是否影响企业利润
  • 组合销售带来的收益
  • 银行转账结算凭证按照填制手续和内容
  • 不用开票的收入有哪些
  • 待摊费用做账
  • 用友t8怎么删除凭证
  • 安装服务需要预缴税款吗
  • 工程业务提成协议合法吗
  • 关于小微企业的规定
  • 如何不同版本复制粘贴
  • 财务红冲是什么意思
  • 出纳日记账填写样本
  • 如何在电脑管家里把健康小程序提取出
  • 新会计规定工会会计制度
  • framework教程
  • 基于中国国情的中国式现代化具有哪些特色
  • 房产无偿过户给朋友能让他还吗?
  • iframe嵌套页面点击里面的按钮
  • 现金折扣发生销售退回
  • oss使用场景
  • 百度地图api的使用
  • but all failed
  • 申请退税怎么算
  • echarts series name
  • linux信号的本质
  • ajax提交表单数据
  • Laravel 5.1 on SAE环境开发教程【附项目demo源码】
  • init 6命令
  • 借款利息记入短期借款吗
  • mysql怎么截取字段
  • 免税公司专用发票是什么
  • 投资性房地产在建期间需要摊销吗
  • 公司购买食品如何入账科目
  • 应交税费账户的用途和结构是怎样的
  • 新公司第一年年度总结
  • 善意取得增值税专用发票所得税
  • 二手车如何计提折旧费
  • 收到发票了填写什么单据
  • 票据比例
  • 红冲发票如何做账
  • 汇算清缴怎么申报
  • 金蝶迷你版为什么打不开
  • 红字发票是怎么开的
  • 公司注册资金可以变更减少吗
  • 在linux操作系统中
  • 虚拟机怎么安装exe文件
  • Win10 Mobile Build 10572 其它未记录更新内容汇总
  • win7文件访问被拒绝怎么办
  • win10更新后qq打不开
  • win8 开始
  • Win10 Mobile Redstone预览版14291上手体验评测
  • Jquery ajax 同步阻塞引起的UI线程阻塞问题
  • python中matplotlib绘制曲线
  • unity控制相机旋转
  • jQuery validate+artdialog+jquery form实现弹出表单思路详解
  • js简单实现图片轮播
  • 石油产品消费税征收
  • 注册地址和税务登记可以不一致吗
  • 农业企业制造费用包括哪些
  • 广州市地方税务局 社保费申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设