Laravel select()返回具有多态关系和交叉联接的空值

时间:2019-10-23 11:58:26

标签: php laravel eloquent laravel-5.8

我有4个表:tv_showstv_show_episodeslanguageslanguageables

由于多态关系,每个电视节目可能有多种语言。 我打算按语言过滤电视节目。同时,我还按照播出的播出日期对电视节目进行排序。

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()方法时,一切正常。

我需要电视节目旁边的那些剧集信息。我想知道是什么原因?

1 个答案:

答案 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是您的模型。 希望对您有帮助。