Laravel 4 获得多个集合

Posted

技术标签:

【中文标题】Laravel 4 获得多个集合【英文标题】:Laravel 4 getting multiple collections 【发布时间】:2015-03-19 21:49:30 【问题描述】:

我正在我的控制器中编写一个函数来返回一个 json 响应。这是我的功能:

public function play($id)
        $quiz = Quiz::find($id);
        $questions = $quiz->question()->get();

        return Response::json(array(
            'quiz' => $quiz,
            'questions' => $questions));
    

这很有效,但是,我也有与问题相关的答案。 在我的Question 模型中,我有这个answer() 函数:

public function answer()
        return $this->hasMany('Answer');
    

在我的Answer 模型中,我当然有我的question() 函数:

public function question()
        return $this->belongsTo('Question');
    

我如何获得答案?我不能使用;

$answers = $question->answer()->get;

我不能用

//get the questions using query, but this returns nothing
$questions = Question::where('quiz_id', '=', $id);
$answers = $questions->answer()->get;

我希望我足够清楚,我尝试搜索但我找不到任何东西,请任何人帮助:)?

【问题讨论】:

【参考方案1】:

您可以使用eager loading 获得答案嵌套在问题内的结果:

$questions = $quiz->question()->with('answer')->get();

如果您只想获得一个问题的答案,请执行以下操作:

$question = Question::find(1);
$answers = $question->answer()->get();

或者干脆使用动态属性

$answers = $question->answer;

旁注:我建议你用复数形式命名hasMany关系。 answers 而不是 answer。这在语义上更有意义,并清楚地告诉您结果是集合还是单个模型。

【讨论】:

渴望加载工作。关于旁注;好东西要记住,谢谢。

以上是关于Laravel 4 获得多个集合的主要内容,如果未能解决你的问题,请参考以下文章

Laravel条件聚合以获得多个金额总和

如何在 Laravel 中正确合并多个集合

Laravel 5.2 pluck() 来自 Eloquent 模型集合的多个属性

laravel 4 分页集合

Laravel 5.7:基于多个键检测集合中的重复项(完成)但如何将重复项移动到另一个集合?

laravel livewire 异常:不支持具有多个模型连接的队列集合