Это мой массив $dataRep:
array:4 [▼
0 => Fields {#7051 ▶}
1 => Fields {#7328 ▶}
2 => Fields {#7334 ▶}
3 => Fields {#7340 ▶}
]
Мне нравится хранить данные с помощью конструктора форм Symfony в базе данных:
$dataEntity= new Data::class();
foreach ($dataRep as $dataField) {
$dataEntity->setContent("something");
}
$this->em->persist($dataEntity);
$this->em->flush();
Но в базе данных хранится только одна запись, а не 4 записи, как ожидалось.
@ Дарра Да, это так.
@yivi о, извините, да, должны быть новые данные();






Переместите свой код в свой цикл, чтобы он выполнялся на каждой итерации:
foreach ($dataRep as $dataField) {
$dataEntity = new Data();
$dataEntity->setContent("something");
$this->em->persist($dataEntity);
}
$this->em->flush();
Примечание: У вас также была синтаксическая ошибка, которую я только что заметил (new Data::class()).
$this->em->flush(); можно использовать один раз, нет?
Вы сбрасываете содержимое того же класса данных, а затем сохраняете его. Просто foreach весь процесс:
foreach ($dataRep as $dataField) {
$dataEntity = new Data();
$dataEntity->setContent("something");
$this->em->persist($dataEntity);
}
$this->em->flush();
flush(); должен быть после foreach, чтобы избежать запроса к базе данных для каждого объекта (и сделать один глобальный запрос, чтобы сохранить все объекты сразу). Как в ответе @Script47
@Etshy, я знаю, это лучшая практика. Я не изменил его, чтобы сохранить свое первоначальное решение, потому что он изменил его, и оба были одинаковыми. В любом случае, я изменил его, чтобы улучшить ответ, несмотря на то, что это 2 раза один и тот же ответ.
Не видел, чтобы другие ответы тоже были отредактированы, извините. но я считаю, что лучше показать код «наилучшей практики», даже если он дубликат, для последующих посетителей этого поста. Итак, спасибо за редактирование ваших ответов.
Разве
new Data::class()не синтаксическая ошибка?