位置: 编程技术 - 正文

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

  • 多缴纳了印花税有什么影响
  • 收到以前年度银行手续费发票
  • 公司注销还能要回钱吗
  • 党费帐常用会计分录
  • 减免的附加税怎么做会计分录
  • 股东投入款放入什么科目
  • 企业之间无偿借款
  • 托管物资账务处理流程
  • 供用电合同主要有
  • 公允价值确定方法最新
  • 农村土地征用补偿是多少钱一亩
  • 与成本直接相关的工资怎么会计处理?
  • 关税应纳税额的计算方法包括
  • 电商公司怎么进入
  • 房产增值税是怎么交的呢
  • 房产赠与流程是什么意思
  • 营改增后一般纳税人动产租赁税率
  • 新办企业国税报税时间
  • 未按规定安装使用税控装置
  • 公司入职员工
  • 个人租赁汽车给公司怎么开发票
  • 自产自用设备税务处理
  • 建厂房的费用怎么记账
  • 企业所得税的工资薪金包括社保
  • 带息的应付票据计算的利息计入财务费用
  • 员工工伤一次性赔偿申请书
  • QuickBooks - QuickBooks是什么进程 有什么用
  • window10主题的颜色浅了
  • laravel数据迁移
  • win7为什么显示多重网络
  • 收境外汇款时怎么操作
  • 现金支付医保报销
  • html 教程
  • spring获取bean的完全限定类名
  • vue做项目的流程
  • 委托第三方收款合法吗
  • discuz怎么修改招聘内容
  • wordpress限制邮箱注册
  • 公司与公司往来账表格怎么制作
  • 企业为其他企业担保有什么责任
  • 先开发票还是先收钱
  • 预提管理费用怎么计算
  • 上期未申报怎么办
  • 制造费用月末一般有余额吗
  • 服务业按什么结算工资
  • 残保金的滞纳金怎么算
  • 请问在accessdemo1
  • mysql命令行工具是什么
  • 出口企业免税要交什么税
  • 非营利组织增值税怎么处理
  • 装潢装修费用属于营改增
  • 事业单位的股东是谁
  • 固定资产一次性扣除政策
  • 销售部门交通费计入什么费用
  • 车子报废车子怎么处理
  • windows2003 IIS6.0 asp配置技巧
  • u盘如何安装win7系统
  • 取消windows开机登录密码
  • 删除windows.old文件夹后 桌面没有了
  • 置顶如何设置固定顺序
  • android4.4w
  • Android与OpenCV2.4.4(2013最新)搭建图像处理框架
  • 好看的css样式代码
  • perl linux命令
  • 不错的意思
  • python利用for循环求1到100的奇数之和
  • oculus dk2
  • DOS命令删除文件夹
  • vb中chr$(13)是什么意思
  • shell函数返回多个值包含数组
  • linux怎么ssh远程
  • Android as Bluetooth Low Energy Peripherial (GATT server).
  • jquery跨域请求有哪些方式
  • jquery的dialog
  • 安卓应用 开发
  • 廊坊银行辟谣了吗
  • 河南省税务局系统最新消息
  • 城镇土地使用税会计分录
  • 印花税属于什么业务类型
  • 国税局和地税局分别征收什么税种
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设