【问题标题】:Get relation with extra information from relation table从关系表中获取与额外信息的关系
【发布时间】:2018-05-01 02:49:27
【问题描述】:

我使用 Laravel 和 Eloquent 来关联两个模型。

很简单,一个网店有很多品牌,但是我需要在关系表中存储一些额外的信息。

我如何得到这个?

我的关系表如下所示:

brand_id   |    webshop_id    |   url

我目前获得包括品牌在内的网上商店的声明是:

$webshop = Webshop::select()
        ->where('slug', $slug)
        ->with('brands')
        ->first();

然后我可以查看 $webshop->brands 但无法访问“url”列。

【问题讨论】:

标签: laravel eloquent relational-database relationship laravel-eloquent


【解决方案1】:

在您的网上商店模型上:

public function brands()
{
    return $this->belongsToMany('App\Brand')->withPivot('url');
}

那就做吧

foreach ($webshop->brands as $brand)
{
    echo $brand->pivot->url; // your url
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2023-02-02
    • 1970-01-01
    • 2014-09-17
    • 2023-03-25
    • 2017-09-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多