DB::beginTransaction(); Nach dem Einschalten kann jedes Mal nur das erste Datenelement eingefügt werden, der Rest wird zurückgesetzt.
Der Code lautet wie folgt:
try {
DB::beginTransaction();
foreach ($rightOrWrongRows as $row) {
$question = array_combine($rightOrWrongHeader, $row);
RightOrWrong::create([
'question' => $question['question'],
'answer' => $question['answer'],
'scope' => $question['scope'],
'degree' => 1,
'exam_id' => $this->examId,
]);
}
DB::commit();
} catch (\Exception $exception) {
DB::rollBack();
Log::info($exception->getMessage());
}
Wenn Sie die Transaktion abschließen, können Sie mehrere Daten einfügen
try {
//DB::beginTransaction();
foreach ($rightOrWrongRows as $row) {
$question = array_combine($rightOrWrongHeader, $row);
RightOrWrong::create([
'question' => $question['question'],
'answer' => $question['answer'],
'scope' => $question['scope'],
'degree' => 1,
'exam_id' => $this->examId,
]);
}
//DB::commit();
} catch (\Exception $exception) {
//DB::rollBack();
Log::info($exception->getMessage());
}
Bitte helfen Sie mir, dieses Problem zu lösen, ich bin ein Neuling.
try
错误信息, 表结构, 图.