首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从Laravel中的关系中检索关系

从Laravel中的关系中检索关系
EN

Stack Overflow用户
提问于 2020-05-06 03:48:04
回答 2查看 38关注 0票数 2

我有一个使用Laravel 7的应用程序,在其中,我有一个“帐户”模型,这个模型有几个“配置文件”,每个“配置文件”都有几个“产品”。

如何以最佳方式检索附加到某些“帐户”的所有“产品”。

目前,我加载所有的“配置文件”链接到这个“帐户”,然后所有的“产品”链接到每个“配置文件”。但我发现这并不是非常优化,并且在对返回的数据进行排序(按降序)时有困难。

我确信Eloquent / Laravel允许直接恢复,但我不知道如何恢复。

多亏了你!

EN

回答 2

Stack Overflow用户

发布于 2020-05-06 03:55:42

代码语言:javascript
运行
复制
Account::with(['profiles','profiles.products'])->get();
票数 4
EN

Stack Overflow用户

发布于 2020-05-06 04:48:02

对于这种情况,eloquent有关系‘有很多直通’,在你的帐户模型中,你可以这样写:

代码语言:javascript
运行
复制
class Account extends Model
{
public function products()
{
return $this->hasManyThrough(Product::class, Profile::class);
}
}

现在,您可以获取指定账户的所有产品,如下所示:

代码语言:javascript
运行
复制
$myAccountProducts=Account::find($account_id)->products()->get();

您还可以指定外键...

更多详细信息请参阅:

https://laravel.com/docs/7.x/eloquent-relationships#has-many-through

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61621756

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档