位置: 编程技术 - 正文

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

  • 房地产开发企业预缴增值税
  • 怎么做掉公司账户的钱
  • 实收资本增加印花税税目
  • 汇算清缴结束后,税务机关发现企业应当取得
  • 高档化妆品增值税税率是13%
  • 养老院营利性与非营利如何认定
  • 附加税减半征收会计分录
  • 个税申报系统累计收入怎么算
  • 汇算清缴补交税款,怎么调整报表教程
  • 电子发票的有效性在哪里查看
  • 股东投资属于什么会计要素
  • 企业所得税的优点有哪些
  • 旅行社的营业收入主要由( )构成
  • 公司租用办公室需要交房产税吗
  • 专票已认证但又没有发票
  • 应付账款逾期利息会计分录
  • 增值税税控设备服务费
  • 公司长期应付账款怎么算
  • 增值税税控系统专用设备抵减增值税
  • 技术开发合同可以开专票吗
  • 收到设备租金计入什么会计科目
  • 代扣代缴的增值税怎么做账
  • 私立医院增值税税率是多少
  • 电子发票没有纳税人识别号有效吗
  • 纳税人转让2016年以后的土地使用权
  • 滞留发票的税收处理
  • 发票连号不许报销吗
  • 金融企业的代理贷款什么意思
  • 企业购车按揭产生的费用
  • 固定资产报废鉴定意见
  • 小规模季度不超过30万的账务处理
  • 财政拨款的贴息怎么计算
  • 系统托盘右键
  • 土地拍卖资金交到哪里
  • 广告业进项都能开什么票
  • 苹果手机删除的备忘录怎么恢复
  • 房屋装修补偿款 避税
  • web前端基本知识
  • 应收账款项目在资产负债表怎么填列
  • 对抗生成网络算法
  • 分公司需要做纳税申报吗
  • python sockets
  • 织梦模板安装详细教程
  • 投资性房地产递延所得税负债为什么计入其他综合收益
  • 月初红字冲销暂估入账
  • 公司帐户转到法人私卡备用金行吗
  • 多处取得工资薪金
  • 固定资产加速折旧计算方法
  • 劳动法辞退员工补偿标准2023
  • 企业付的房租税费会计分录
  • 计提社保公积金个税会计分录
  • 以前年度费用科目入错 不影响以前年度利润的账务处理
  • 专利申请费用能走工会会费吗
  • 以前年度的亏损
  • 没有公章的发票
  • 私人公司盈利怎么把钱拿出来
  • MySQL ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) 的原因分解决办法
  • win7系统c盘太满了,如何清理
  • linux存在的意义
  • Centos系统里screen命令如何使用?Centos系统里screen命令的使用方法
  • ubuntu20.10
  • WINDOWS操作系统内置的GUEST
  • linux用户管理器在哪
  • 苹果mac使用
  • mac未能分区
  • u深度如何装win7系统
  • 你可能不知道的中融新大
  • 非常好的成语
  • unity判断点击ui
  • css制作排行榜
  • css-div
  • Clipboard.js 无需Flash的JavaScript复制粘贴库
  • shell脚本获取文件指定内容
  • python魔法方法有啥用
  • 设置自定义
  • 资本公积如何转增股本的流程
  • 个人所得税是哪种税率
  • 税务暂停办理业务通知
  • 本期应纳税额怎么算
  • 小规模纳税人需要进项票吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设