[英]How can I limit selected columns from an eloquent relationship?
我有一个3项的概念都存储在一个数据库中,并在它们之间定义了关系。 这些项目反映了调查的答案。 表格是:
结果:id,enrolment_id,assessment_id,completed(int),timestamps result_answers:id,result_id,answer_id,timestamps answers: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
的关系(这是有效的)。
我试过with()
提供一个空的->select()
with()
但没有运气。
任何帮助赞赏。
结果与答案之间存在多对多关系,您不应该关心中间的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。
您可以将get()
中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'])
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.