如何从雄辩的关系中限制选定的列?

时间:2016-09-05 10:09:04

标签: php laravel laravel-5 eloquent laravel-5.2

我有一个3项的概念都存储在数据库中,并且它们之间定义了关系。这些项目反映了调查的答案。表格是:

结果:id,enrolment_id,assessment_id,completed(int),timestamps result_answers:id,result_id,answer_id,timestamps 答案:id,answer_plain,answer_html,timestamps

我正在尝试构建一个包含以下内容的对象:

Results (array){
  id, enrolment_id, assessment_id, created_at
  Result_answers (array){
    Answer{
      id,answer_plain
    }
  }
}

我使用以下代码:

$result = Result::where('enrolment_id', '=', $id)
    ->where('completed', '=', 1)
    ->with(['result_answers' => function($query) {
        $query->with(['answer' => function($query) {
            $query->select('id', 'answer_plain');
        }]);
    }])
    ->select(['id', 'enrolment_id', 'created_at'])
    ->get();
return response()->json($result);

不幸的是,这给了我很多不需要的字段,有效地输出了每个关系中每个表中的每个字段。如何限制输出的内容?它似乎主要是result_answers的问题,因为我不需要来自该表输出的任何数据,只需要与answer(正在工作)的关系。

我尝试向->select()提供一个空的with(),但没有运气。

任何帮助表示感谢。

2 个答案:

答案 0 :(得分:0)

结果答案之间存在多对多关系,您不应该非常关心中间 result_answers 表。您不应该在模型中将关系定义为 results_answers 表。

所有与加载数据相关的工作都应由Eloquent完成,前提是您已正确定义关系。

您的模型应包含以下关系:

class Result extends Model {
  public function answers() {
    return $this->belongsToMany(Answer::class, 'results_answers');
  }
}

通过定义,您应该能够以更简单的方式获得结果的答案:

$results = Result::where('enrolment_id', '=', $id)
  ->where('completed', '=', 1)
  ->with(['answers' => function($query) {
        $query->select('id', 'answer_plain');
  }])
  ->select(['id', 'enrolment_id', 'created_at'])
 ->get();

现在,您应该能够通过以下方式迭代结果和相关答案:

foreach ($results as $result) {
  foreach ($result->answers as $answer) {
    var_dump($answer);
  }
}

您也可以替换:

return response()->json($results);

与     返回$ results;

因为从控制器返回的所有jsonable内容都会自动序列化为JSON,然后才会返回到浏览器。

答案 1 :(得分:0)

您可以将get()中所需的所有字段作为数组键函数传递:

$results = Result::where('enrolment_id', '=', $id)
->where('completed', '=', 1)`
  ->with(['answers' => function($query) {
    $query->get(['id', 'answer_plain']);
  }])->get(['id', 'enrolment_id', 'created_at'])