簡體   English   中英

從三個具有關系 laravel 的模型中獲取數據

[英]Get data from three models with relationship laravel

我有三個模型:

意甲 ($id)

public function saisons() 
{
    return $this->hasMany(Season::class);
}

public function episodes() 
{
    return $this->hasManyThrough(Episode::class, Season::class);
}

賽季($serie_id)

public function serie()
{
    return $this->belongsTo(Serie::class);
}

public function episodes() 
{
    return $this->hasMany(Episode::class);
}

劇集($season_id)

public function season()
{
    return $this->belongsTo(Season::class);
}

public function serie()
{
    return $this->BelongsToThrough(Serie::class, Season::class);
}

我想展示一個系列中的一個特定季節以及相關的劇集

我的觀點

<h1 class="title">{{$serie->seasons->number}}</h1>


@foreach ($serie->seasons->episodes as $episode)

        <div class="row">
            <div class="columns">
                <div class="col">
       {{$episode->number}}
       <a href="{{route('episodes.show', $episode->id)}}">{{$episode->name}}</a>



        @if(isset($episode->programmation->date))

            {{$episode->programmation->date}}

        @endif
       @if (($episode->season_finale) == '0')
            Non
            @elseif (($episode->season_finale) == '1')
            Oui
            @endif

        @foreach ($episode->chaines as $chaine)
                   {{$chaine->name}}

            @endforeach
        </div>
        </div>
    </div>
    @endforeach

路線

Route::get('/serie/{serie}/saison/{season}', 'Front\SaisonController@show')->name('saison.show');

對於我的 url,我選擇顯示 saison 的編號而不是 id,我認為這就是問題所在。

我怎樣才能以適當的方式做到這一點?

我認為這種方法可以幫助你。

$serie = Serie::where('id',$id)->with('seasons'=>function($query) use ($season_id) {
            $query->where('season_id',$season_id)->with('episodes')->get();
    })->get();

好的,有人幫我找到正確的答案:

     $serie = Serie::findOrFail($serie);
     $season =  Season::where('serie_id', $serie->id)->where('season.number', $season)->first();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM