位置: 编程技术 - 正文

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

  • 什么是土地使用权终结
  • 没有购销合同可以开票吗
  • 预缴税款是什么科目
  • 什么类型的电子商务
  • 私车公用是否合法
  • 房地产企业没有退还的履约保证金税务
  • 常见的税收优惠
  • 公司买入股票要交所得税吗?
  • 房租费可以摊销吗
  • pos机刷卡的银行有哪些
  • 没有实收资本是负债吗
  • 土地使用税与房产税的区别
  • 海关缴款书抵扣怎么做账
  • 已交税金是什么科目
  • 营改增一般纳税人申请过渡性财政扶持资金
  • 居民企业非货币性资产投资、转让所得如何缴税?
  • 垫付的医药费怎么理赔
  • 收到押金入什么会计科目
  • 诉讼过程中
  • 建筑行业会计成本会计工作流程
  • 华为最新款手机2023款
  • 清理血管垃圾最有效的食物
  • win7系统中如何让未响应的程序继续运行
  • 房东不开发票违法吗
  • 视同销售怎么做账务处理
  • 简易征收增值税怎么算
  • 右键菜单中没有RAR压缩项怎么办
  • PHP:Memcached::replace()的用法_Memcached类
  • 编写一个php程序,展示双引号和单引号的区别
  • devtools安装mac
  • Vue+Element UI-el-date-picker时间日期选择器组件(实现向后端传值)
  • paper 1
  • php gdb
  • Yii2中SqlDataProvider用法示例
  • mysqlbinlog -vv
  • 带息应收票据账务处理分录
  • 企业有代扣代缴个税义务
  • 利润分配的账务处理会计分录
  • 本年累计金额怎么得到
  • python默认画布大小
  • 高效刷题app
  • 个人所得税0申报什么意思
  • 债务豁免会计核算
  • 清空表sql语句
  • 通货紧缩的影响简答题
  • 企业代扣代缴个税
  • 抵账协议上可以签字吗
  • 学历教育服务增值税
  • 现金比率的计算公式是什么意思
  • 固定资产出售算营业收入吗
  • 公司员工出差住酒店费用明细有问题怎么办
  • 先清卡后报税影响申报吗
  • 异地缴纳增值税和附加税的区别
  • 价税分离怎么算
  • 非正常损失进项税额转出计算
  • 建账及账务处理步骤
  • mysql大小
  • MySQL数据库安装后通常默认的管理员用户名为
  • vmware如何用
  • 还原windows是什么意思
  • centos如何安装vim
  • win8系统怎么设置
  • 如何把windowsxp换成windows7
  • 命令行教程
  • win7连接xp共享
  • 运行ghost
  • centos7 ip命令
  • nmeo.exe是什么
  • window10的微软商店在哪
  • linux命令行图片
  • linux的虚拟终端有几个
  • 彻底理解样本方差为何除以n-1
  • 怎样用在js中使用css的内容
  • 模板创造
  • windowsxp命令行窗口怎么打开
  • python 初级
  • unity地形图片
  • 包装物押金收入含税吗
  • 自来水征税
  • 广东省电子职业技术学院
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设