我有一个使用Laravel 7的应用程序,在其中,我有一个“帐户”模型,这个模型有几个“配置文件”,每个“配置文件”都有几个“产品”。
如何以最佳方式检索附加到某些“帐户”的所有“产品”。
目前,我加载所有的“配置文件”链接到这个“帐户”,然后所有的“产品”链接到每个“配置文件”。但我发现这并不是非常优化,并且在对返回的数据进行排序(按降序)时有困难。
我确信Eloquent / Laravel允许直接恢复,但我不知道如何恢复。
多亏了你!
发布于 2020-05-06 03:55:42
Account::with(['profiles','profiles.products'])->get();
发布于 2020-05-06 04:48:02
对于这种情况,eloquent有关系‘有很多直通’,在你的帐户模型中,你可以这样写:
class Account extends Model
{
public function products()
{
return $this->hasManyThrough(Product::class, Profile::class);
}
}
现在,您可以获取指定账户的所有产品,如下所示:
$myAccountProducts=Account::find($account_id)->products()->get();
您还可以指定外键...
更多详细信息请参阅:
https://laravel.com/docs/7.x/eloquent-relationships#has-many-through
https://stackoverflow.com/questions/61621756
复制相似问题