我有一个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()
,但没有运气。
任何帮助表示感谢。
答案 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'])