我有4个表:tv_shows
,tv_show_episodes
,languages
和languageables
由于多态关系,每个电视节目可能有多种语言。 我打算按语言过滤电视节目。同时,我还按照播出的播出日期对电视节目进行排序。
TvShow::select([
'tv_shows.*',
'tv_show_episodes.id as episode_id',
'tv_show_episodes.name as episode_name',
'tv_show_episodes.air_date as episode_air_date',
'tv_show_episodes.season_number',
'tv_show_episodes.episode_number',
'tv_show_episodes.still_path',
])
->crossJoin('tv_show_episodes', 'tv_shows.id', '=', 'tv_show_episodes.tv_show_id')
->whereRaw('timestamp(concat(tv_show_episodes.air_date, " ", tv_shows.airs_time)) <= NOW()')
->orderByRaw('timestamp(concat(tv_show_episodes.air_date, " ", tv_shows.airs_time)) DESC')
->when($request->has('languages'), function($query) {
$query->whereHas('languages', function (Builder $query) {
$query->whereIn('iso_639_1', explode(',', request('languages')));
});
})->paginate(10)
TvShow.php
public function languages()
{
return $this->morphToMany(Language::class, 'languageable');
}
最后,我将它们分10分。当我看到total
可以返回正确的值时,但是data
始终为空。
{
"current_page":1,
"data":[],
"from":null,
"last_page":1760,
"per_page":10,
"to":null,
"total":17600
}
有趣的是,当我从上述查询中删除select()
方法时,一切正常。
我需要电视节目旁边的那些剧集信息。我想知道是什么原因?
答案 0 :(得分:1)
尝试以下答案,
TvShow::selectRaw('`tv_shows`.*, `tv_show_episodes`.`id` as `episode_id`, `tv_show_episodes`.`name` as `episode_name`, `tv_show_episodes`.`air_date` as `episode_air_date`, `tv_show_episodes`.`season_number`, `tv_show_episodes`.`episode_number`, `tv_show_episodes`.`still_path`')
->crossJoin('tv_show_episodes', 'tv_shows.id', '=', 'tv_show_episodes.tv_show_id')
->whereRaw('timestamp(concat(tv_show_episodes.air_date, " ", tv_shows.airs_time)) <= NOW()')
->orderByRaw('timestamp(concat(tv_show_episodes.air_date, " ", tv_shows.airs_time)) DESC')
->when($request->has('languages'), function($query) {
$query->whereHas('languages', function (Builder $query) {
$query->whereIn('iso_639_1', explode(',', request('languages')));
});
})->paginate(10)
在这里,TvShow
是您的模型。
希望对您有帮助。