- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
这听起来像是一个显而易见的问题,但我只是想得到一些保证。
使用 Laravel 的预加载功能,据我所知,它将创建两个查询 以返回相关结果的完整列表(假设您正在使用两个表)。但是,如果我错了,请纠正我,使用连接语句只会让您有一个查询,这会减少到服务器数据库 (MySQL) 的往返次数,并且是一种更高效的查询。
我知道你可以在 Laravel 中编写连接查询,这很棒,所以问题是:我是否错误地假设当从两个或多个表中检索相关数据时,我是否应该不用急于加载而只是写我自己的连接语句?
****** 编辑 *******
一年后回到这个问题上,我个人认为,只写查询,原始的,并且写得很好。
********* 编辑 2 *********
好吧,六年后的现在,我一直为此获得积分。
无论我是否从一开始就不清楚,与我上面所说的相反,Eloquent 在这一点上写出了很好的查询。 使用 Eloquent - 即使查询效率稍低,它也能让你编写非常清晰、可维护的代码,在我职业生涯的这个阶段,我认为这在大多数情况下更为重要个案。仅在性能增强至关重要且您可以衡量影响的情况下编写原始查询和优化。
最佳答案
您的理解完全正确。如果您在 Laravel
中使用 join()
编写 join
语句来连接两个或多个表,那么它只会在使用 的情况下进行一次查询>具有
模型需要多个查询。eager loading
技术的 Eloquent
should I not bother with eager loading and instead just write my own join statements
实际上,eager loading
是一种使用 Eloquent ORM
轻松加载相关模型的技术,它在后台使用 Query Builder
并让您使用 Eloquent Model Object
无需自己进行查询并以不同方式表示数据,使用 Eloquent ORM
您可以直接与表示数据库中对象的模型交互附加的功能。最重要的是,它隐藏了 SQL
的复杂性,并允许您使用 PHP
代码以 OOP 方式进行数据库查询。
但是当您手动调用属于 Illuminate\Database\Query\Builder
类的 join
方法时,您将直接使用 Query Builder
这需要您编写更多代码并需要更多关于 sql 查询
的知识,因为它不会向您隐藏查询,但可以帮助您更精确地进行查询,但您仍然会进行查询。
两者是不同的东西,它们的工作方式也不同。您可以使用术语 ORM vs Query Builder
在 Google
上进行搜索。
关于mysql - Laravel 急切加载与显式连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24271416/
我想要显示正在加载的 .gif,直到所有内容都已加载,包括嵌入的 iframe。但是,目前加载 gif 会在除 iframe 之外的所有内容都已加载后消失。我怎样才能让它等到 iframe 也加载完毕
首先,这是我第一次接触 Angular。 我想要实现的是,我有一个通知列表,我必须以某种方式限制 limitTo,因此元素被限制为三个,在我单击按钮后,其余的应该加载。 我不明白该怎么做: 设置“ V
我正在尝试在我的设备上运行这个非常简单的应用程序(使用 map API V2),并且出于某种原因尝试使用 MapView 时: 使用 java 文件: public class MainMap e
我正在使用 Python 2.6、Excel 2007 Professional 和最新版本的 PyXLL。在 PyXLL 中加载具有 import scipy 抛出异常,模块未加载。有没有人能够在
我想做这个: 创建并打包原始游戏。然后我想根据原始游戏中的蓝图创建具有新网格/声音/动画和蓝图的其他 PAK 文件。原始游戏不应该知道有关其他网格/动画/等的任何信息。因此,我需要在原始游戏中使用 A
**摘要:**在java项目中经常会使用到配置文件,这里就介绍几种加载配置文件的方法。 本文分享自华为云社区《【Java】读取/加载 properties配置文件的几种方法》,作者:Copy工程师。
在 Groovy 脚本中是否可以执行条件导入语句? if (test){ import this.package.class } else { import that.package.
我正在使用 NVidia 视觉分析器(来自 CUDA 5.0 beta 版本的基于 eclipse 的版本)和 Fermi 板,我不了解其中两个性能指标: 全局加载/存储效率表示实际内存事务数与请求事
有没有办法在通过 routeProvider 加载特定 View 时清除 Angular JS 存储的历史记录? ? 我正在使用 Angular 创建一个公共(public)安装,并且历史会积累很多,
使用 Xcode 4.2,在我的应用程序中, View 加载由 segue 事件触发。 在 View Controller 中首先调用什么方法? -(void) viewWillAppear:(BOO
我在某些Django模型中使用JSONField,并希望将此数据从Oracle迁移到Postgres。 到目前为止,当使用Django的dumpdata和loaddata命令时,我仍然没有运气来保持J
创建 Nib 时,我需要创建两种类型:WindowNib 或 ViewNib。我看到的区别是,窗口 Nib 有一个窗口和一个 View 。 如何将 View Nib 加载到另一个窗口中?我是否必须创建
我想将多个env.variables转换为静态结构。 我可以手动进行: Env { is_development: env::var("IS_DEVELOPMENT")
正如我从一个测试用例中看到的:https://godbolt.org/z/K477q1 生成的程序集加载/存储原子松弛与普通变量相同:ldr 和 str 那么,宽松的原子变量和普通变量之间有什么区别吗
我有一个重定向到外部网站的按钮/链接,但是外部网站需要一些时间来加载。所以我想添加一个加载屏幕,以便外部页面在显示之前完全加载。我无法控制外部网站,并且外部网站具有同源策略,因此我无法在 iFrame
我正在尝试为我的应用程序开发一个Dockerfile,该文件在初始化后加载大量环境变量。不知何故,当我稍后执行以下命令时,这些变量是不可用的: docker exec -it container_na
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我刚刚遇到一个问题,我有一个带有一些不同选项的选择标签。 现在我想检查用户选择了哪些选项。 然后我想将一个新的 html 文件加载到该网站(取决于用户选中的选项)宽度 javascript,我该怎么做
我知道两种保存/加载应用程序设置的方法: 使用PersistentStore 使用文件系统(存储,因为 SDCard 是可选的) 我想知道您使用应用程序设置的做法是什么? 使用 PersistentS
我开始使用 Vulkan 时偶然发现了我的第一个问题。尝试创建调试报告回调时(验证层和调试扩展在我的英特尔 hd vulkan 驱动程序上可用,至少它是这么说的),它没有告诉我 vkCreateDeb
我是一名优秀的程序员,十分优秀!