Laravel雄辩的关系查询不起作用

时间:2017-10-12 13:27:20

标签: laravel-5 laravel-eloquent

我想获得有course_id的主题的所有测验:

Topic模型具有以下功能:

public function quizzes()
{
    return $this->hasMany('App\Quiz');
}

Quizzes模型具有以下功能:

public function topic()
{
    return $this->belongsTo('App\Topic', 'topic_id');
}

这是我的控制器功能中的代码:

$topics = Topic::with('quizzes')->whereCourseId($course_id)->orderBy('created_at', 'asc')->get();

return dd($topics->quizzes);

我收到以下Exception错误:

Property [quizzes] does not exist on this collection instance.

我似乎不知道发生了什么事?

1 个答案:

答案 0 :(得分:1)

这是因为你想获得quizzes集合而不是一个模型,所以这样循环遍及这个集合:

foreach ($topics as $topic) {
    $topics->quizzes;  // <- this is fine :)
}

出于调试目的,您可以这样做:

dd($topics->fist()->quizzes);

对于第二种需要,你可以这样做:

$quizzes = Quizzes::whereHas('topic', function ($query) use ($course_id) {
        $query->where('course_id', $course_id);
    })->get();