
本文旨在帮助开发者解决在构建测验系统时,无法正确保存测验答案的问题。通过分析代码结构和模型关系,找出createMany方法使用不当导致的错误,并提供一种使用循环创建问题和答案的解决方案,确保测验标题、问题以及答案都能成功保存到数据库中。
在构建测验系统时,保存测验数据到数据库是一个常见的任务。然而,在处理问题和答案之间的关系时,可能会遇到一些挑战。本文将针对“无法保存测验答案”的问题,提供一种解决方案,帮助开发者正确地将测验数据存储到数据库中。
问题的核心在于以下代码行:
$storeQuiz->questions()->answers()->createMany($data['answers']);
错误信息 Call to undefined method Illuminate\Database\Eloquent\Relations\HasMany::answers() 表明,$storeQuiz->questions() 返回的是一个 HasMany 关系,而 HasMany 关系本身并没有 answers() 方法。这是因为我们需要先创建问题,然后才能在该问题下创建答案。
为了解决这个问题,我们需要使用循环来逐个创建问题,并在每个问题下创建答案。以下是修改后的代码:
$storeQuiz = $quizzes->create($data['title']);
foreach($data['questions'] as $q){
$question = $storeQuiz->questions()->create($q);
$question->answers()->createMany($data['answers']);
}这段代码的逻辑如下:
以下是完整的 store 方法的代码示例:
public function store(Quizze $quizzes)
{
$data = request()->validate([
'title' => 'required', // 修改为 'title' => 'required'
'questions.*.question' => 'required',
'answers.*.answer' => 'required',
], [
'title.required' => 'გთხოვთ, შეიყვანოთ ქვიზის სახელი.', // 修改为 'title.required'
'questions.*.question.required' => 'გთხოვთ, შეიყვანოთ შეკითხვა.',
'answers.*.answer.required' => 'გთხოვთ, შეიყვანოთ პასუხი.'
]);
$storeQuiz = $quizzes->create(['title' => $data['title']]); // 修改为 ['title' => $data['title']]
foreach($data['questions'] as $q){
$question = $storeQuiz->questions()->create($q);
$question->answers()->createMany($data['answers']);
}
return redirect('admin/quizzes');
}注意事项:
通过使用循环来逐个创建问题,并在每个问题下创建答案,我们可以解决“无法保存测验答案”的问题。这种方法确保了问题和答案之间的关系正确建立,并且所有数据都能成功保存到数据库中。在实际开发中,请根据你的具体需求进行适当的调整。
以上就是解决测验答案无法保存的问题的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号