【问题标题】:Laravel eloquent relationship query does not workLaravel 雄辩的关系查询不起作用
【发布时间】:2017-10-12 13:27:19
【问题描述】:

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

Topic 模型具有以下功能:

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

测验模型具有以下功能:

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.

我好像不知道发生了什么?

【问题讨论】:

    标签: laravel-5 laravel-eloquent


    【解决方案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();
    

    【讨论】:

    • 有没有办法在没有循环的情况下获取主题?我想立即获得测验列表吗?
    • 这不是您所要求的:p 您想要所有具有课程 ID 主题的测验列表是真的吗?
    • 是的,这就是我想要的。有什么想法吗?
    猜你喜欢
    • 1970-01-01
    • 2023-04-07
    • 2019-08-13
    • 1970-01-01
    • 2021-06-17
    • 2016-07-01
    • 2020-08-27
    • 1970-01-01
    相关资源
    最近更新 更多