教义2实体未填充childs元素

时间:2019-07-03 21:16:13

标签: doctrine-orm doctrine one-to-many

在数据库中,我有两个相关的表。

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 Service数据

$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;

1 个答案:

答案 0 :(得分:1)

这是因为运行时

$appBooking = $this->bookingService->findOne($id);

该实体是从其内部代理缓存中获取的。没有执行数据库查询来获取实体的数据。其已加载的关联也是如此。 代理缓存在执行http请求期间有效。

要解决此问题,您必须手动更新$services集合或 refresh 实体。

$this->em->refresh($appBooking);
  

从数据库刷新实体的持久状态,覆盖所有尚未持久的本地更改。

您还可以 clear 之前调用findOne()方法。

$this->em->clear();
  

清除EntityManager。当前由此EntityManager管理的所有实体都已分离。

参考