В моей базе данных у меня есть две связанные таблицы.
AppBooking
AppBookingService
AppBookingService имеет внешний ключ для AppBooking
Я использую этот метод для вставки как в первую, так и во вторую таблицу.
public function bookingExecute($data){
try{
$this->em->beginTransaction();
$appBooking = $this->_fillAppBooking($data);
$this->em->persist($appBooking);
if (array_key_exists("appService",$data) && is_array($data['appService']) && count($data['appService']) > 0){
foreach($data['appService'] as $bookingService){
$appBookingService = $this->_fillAppBookingService($bookingService,$appBooking);
$this->em->persist($appBookingService);
$this->em->flush();
}
}
$this->em->flush();
$this->em->commit();
return $appBooking;
}catch (\Exception $ex){
$this->em->rollback();
throw new BookingException("",BookingError::BOOKING_QUERY_ERROR);
}
}
Данные написаны правильно
После этого в том же http-запросе я вызываю приведенный ниже метод, чтобы иметь данные службы AppBooking в моем объекте.
$appBooking = $this->bookingService->findOne($id);
Проблема в том, что объект AppBooking, который я получаю, не содержит AppBookingService
Метод
$appBooking->getServices()->count()
возвращает 0
Если я сделаю тот же вызов в другом http-запросе, я получу желаемый результат.
Как будто доктрина не обновляла объект в том же запросе.
Это часть AppBooking
/**
* @var Collection
* @ORM\OneToMany(targetEntity = "AppBookingService", mappedBy = "idBooking")
*/
private $services;
public function __construct() {
$this->services = new ArrayCollection();
}
Это часть AppBookingService
/**
* @var \Entity\Entity\AppBooking
*
* @ORM\ManyToOne(targetEntity = "Entity\Entity\AppBooking", inversedBy = "services")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name = "ID_BOOKING", referencedColumnName = "ID_BOOKING", nullable=true)
* })
*/
private $idBooking;





Это потому, что при запуске
$appBooking = $this->bookingService->findOne($id);
Сущность извлекается из его внутреннего кэша прокси. Запрос к базе данных для получения данных объекта не выполняется. То же самое верно и для его уже загруженных ассоциаций. Кэш прокси действителен во время выполнения HTTP-запроса.
Чтобы решить эту проблему, вам нужно либо обновить коллекцию $services вручную, либо обновить сущность.
$this->em->refresh($appBooking);
Refreshes the persistent state of an entity from the database, overriding any local changes that have not yet been persisted.
Вы также можете Чисто весь кеш диспетчера сущностей до, вызвав метод findOne().
$this->em->clear();
Clears the EntityManager. All entities that are currently managed by this EntityManager become detached.
использованная литература