我有一个3项的概念都存储在一个数据库中,并在它们之间定义了关系.这些项目反映了调查的答案.表格是:
结果:id,enrolment_id,assessment_id,completed(int),timestamps
result_answers:id,result_id,answer_id,timestamps
答案:id,answer_plain,answer_html,时间戳
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的问题,因为我不需要来自该表输出的任何数据,只需要回答的关系(这是有效的).
我试过用()提供一个空的> select()但没有运气.
任何帮助赞赏.
解决方法:
结果与答案之间存在多对多关系,您不应该关心中间的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;